SpringBoot2.3.0配置JPA的实现示例
JPA顾名思义就是JavaPersistenceAPI的意思,是JDK5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中。
依赖
- spring-boot-starter-data-jdbc
- spring-boot-starter-data-jpa
- mysql-connector-java
org.springframework.boot spring-boot-starter-data-jdbc org.springframework.boot spring-boot-starter-data-jpa mysql mysql-connector-java runtime
application.yml
spring.jpa.hibernate.ddl-auto=update
- 如果数据库内没有表或表结构改变时根据Entity创建/更新
spring.jpa.show-sql=true
- 控制台打印sql
spring.jpa.database
- 指定数据库类型,可写可不写
spring: datasource: driver-class-name:com.mysql.cj.jdbc.Driver url:jdbc:mysql://localhost:3306/spring_boot?serverTimezone=GMT%2B8 username:root password:root jpa: hibernate: ddl-auto:update show-sql:true database:mysql
POJO
- @Data是Lombok
- @Entity告诉JPA这是一个实体类(和数据表映射的类)
- @Table(name=“jpa_user”)给表起名,不写默认为类名小写(user)
- @Id设置主键
- @GeneratedValue(strategy=GenerationType.IDENTITY)使用自增
- @Column(name=“jpa_username”,length=40)给列起名,不写默认为属性名(username)
importlombok.Data; importjavax.persistence.*; @Entity @Table(name="jpa_user") @Data publicclassUser{ @Id @GeneratedValue(strategy=GenerationType.IDENTITY) privateIntegerid; @Column(name="jpa_username",length=40) privateStringusername; @Column(name="jpa_password") privateStringpassword; }
Repository
JpaRepository的继承关系
- JpaRepository
- 第一个泛型就是要操作的Entity
- 第二个泛型就是Entity的Id主键类型
- JpaRepository
packagecom.live.repository; importcom.live.model.User; importorg.springframework.data.jpa.repository.JpaRepository; publicinterfaceUserRepositoryextendsJpaRepository{ }
@Autowired@Autowired UserRepositoryuserRepository;
packagecom.live.controller; importcom.live.model.User; importcom.live.repository.UserRepository; importorg.springframework.beans.factory.annotation.Autowired; importorg.springframework.web.bind.annotation.GetMapping; importorg.springframework.web.bind.annotation.PathVariable; importorg.springframework.web.bind.annotation.RestController; importjava.util.List; importjava.util.Optional; @RestController publicclassUserJPAController{ @Autowired UserRepositoryuserRepository; @GetMapping("/findAll") publicListfindAll(){ returnuserRepository.findAll(); } @GetMapping("/findOne/{id}") publicOptional findOne(@PathVariable(value="id")Integerid){ returnuserRepository.findById(id); } @GetMapping("/insert") publicUserinsertOne(Useruser){ returnuserRepository.save(user); } }
注意:
- 对字段操作时,使用的是实体类的属性名(username,password)
- 而不是在@Column(name=“jpa_username”)设置的jpa_username
查询所有
插入
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。