Spring Boot 2.X快速整合jpa过程解析
2019-10-29 07:07
1231 查看
一、JPA介绍
JPA是Java Persistence API的简称,中文名Java持久层API,是JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中。
SpringData是Spring的一个子项目。用于简化数据库访问,支持NoSQL和关系数据存储,其主要目标是使数据库的访问变得方便快捷。
Spring Data JPA致力于减少数据访问层(DAO)的开发量,开发者唯一要做的就只是声明持久层的接口,其他都交给Spring Data JPA 来帮你完成!
二、Spring Data JPA类结构图
1、类的结构关系图
三、代码实现
1、添加对应的Starter
pom.xml中添加下面依赖
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>runtime</scope> </dependency>
2、添加连接数据库的配置
#修改tomcat默认端口号 server.port=8090 #配置数据源信息 spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://192.168.0.1:3306/test spring.datasource.username=root spring.datasource.password=123456 #配置jpa spring.jpa.hibernate.ddl-auto=update spring.jpa.show-sql=true spring.jackson.serialization.indent_output=true
3、主要代码
UserRepository.java
/** * 注意: * 1.这里这里是interface,不是class * 2.CrudRepository里面的泛型,第一个是实体类,第二个是主键的类型 */ public interface UserRepository extends CrudRepository<User, Integer> { @Query("from User where id =:id ") public User getUser(@Param("id") Integer id); }
User.java
@Entity @Table(name = "user") public class User { @Id @GeneratedValue(strategy = GenerationType.AUTO) private Integer id; private String name; private String password; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } }
UserController.java
@RestController public class UserController { @Autowired UserService service; /** * 根据id 查询 */ @RequestMapping("/getUser/{id}") public User getUser(@PathVariable("id") Integer id) { return service.getUser(id); } /** * 根据id 删除 */ @RequestMapping("/deleteUser/{id}") public String deleteUser(@PathVariable("id") Integer id) { service.deleteUser(id); return "删除成功!"; } }
user表数据截图如下:
项目启动成功后访问http://localhost:8090/getUser/2和http://localhost:8090/deleteUser/2后截图如下:
到此发送Spring Boot整合JPA全部实现,有问题欢迎留言沟通哦!
完整源码地址: https://github.com/suisui2019/springboot-study
以上就是本文的全部内容,希望对大家的学习有所帮助
您可能感兴趣的文章:
相关文章推荐
- Spring Boot整合Spring Data JPA过程解析
- Spring Boot 2.X 如何快速整合jpa?
- Spring Boot 整合 Shiro+Thymeleaf过程解析
- springboot整合redis集群过程解析
- SpringBoot整合Spring Data Jpa(快速入门,自定义查询)
- SpringBoot整合Lettuce redis过程解析
- SpringBoot 快速整合Mybatis(去XML化+注解进阶)
- 第二十四章:SpringBoot项目整合JPA多数据源配置
- Spring Boot+JPA+Mysql+ThymeLeaf快速构建CURD系统(一)Spring Boot介绍
- Spring Boot+JPA+Mysql+ThymeLeaf快速构建CURD系统(二)搭建SpringBoot工程
- 详解SpringBoot 快速整合MyBatis(去XML化)
- SpringBoot集合Mybatis过程解析
- SpringBoot(二) springboot整合jdbc和jpa
- Spring Boot+JPA+Mysql+ThymeLeaf快速构建CURD系统(四)构建前端
- 初学spring boot 记录下过程-整合mybatis(三)
- SpringBoot简单整合SpringDataJpa
- SpringBoot学习笔记(五) --- SpringBoot整合JPA
- Spring Boot与Mybatis 借助Fastjson快速完成数据解析入库
- Spring Boot(二):整合 JPA 及 事务控制
- Spring Boot 2.X 快速集成单元测试解析