spring data jpa 学习笔记

时间:2023-03-08 17:11:46

springboot 集成 springData Jpa

1.在pom.xml添加依赖

 <!-- SpringData-Jpa依赖-->
<dependency
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency> <!-- mysql驱动:com.mysql.jdbc.Driver -->

2.application.xml中配置数据库连接信息,自动创建表结构设置

 spring.datasource.url=jdbc:mysql://localhost:3306/test
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.jpa.properties.hibernate.hbm2ddl.auto=create-drop

Spring-data-jpa依赖于Hibernate 
spring.jpa.properties.hibernate.hbm2ddl.auto是hibernate的配置属性,主要作用是:自动创建、更新、验证数据库表结构

参数配置介绍:
create:
每次加载hibernate时都会删除上一次的生成的表,
然后根据model类重新生成表,哪怕没有改变,
这是导致数据库表数据丢失的一个重要原因。
create-drop:
每次加载hibernate时根据model类生成表,但sessionFactory关闭时,表自动删除。
update:最常用
首次加载hibernate时根据model类自动建立起表结构(要先建立数据库)
以后加载hibernate时根据model类自动更新表结构,即使表结构变了,老数据不删除。
注意:当部署到服务器后,表结构不会立即建立起来,应用首次运行后才会建立表结构。
validate:
每次加载hibernate时,验证创建数据库表结构,和数据库表比较,不创建新表,会插入新值。

创建User实体,会被映射到数据库 
hibernate.hbm2ddl.auto,应用启动时自动创建表

 @Entity
public class User { //没有默认构造会报错
public User(){ } public User(String name, Integer age) {
this.name = name;
this.age = age;
} @Id
@GeneratedValue
private Long id; @Column(nullable = false)
private String name; @Column(nullable = false)
private Integer age; public Long getId() {
return id;
} public void setId(Long id) {
this.id = id;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public Integer getAge() {
return age;
} public void setAge(Integer age) {
this.age = age;
} }

Dao接口 继承 JpaRepository接口 完成数据访问

 public interface UserRepository extends JpaRepository<User, Long> {

     User findByName(String name);

     @Query("from User u where u.name=:name")
User findUser(@Param("name") String name); }