SpringBoot 整合 SpringDataJPA

时间:2022-07-26
本文章向大家介绍SpringBoot 整合 SpringDataJPA,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

1.1 已有项目增加 SpringDataJPA

☞ 添加依赖

  一个 SpringBoot 项目想要使用 SpringDataJPA 必须先添加 SpringDataJPA 相关依赖,其次,SpringDataJPA 会用到数据库驱动,所以也需要导入数据库驱动的依赖

<!-- springBoot JPA的起步依赖 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>

<!-- MySQL连接驱动 -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>

☞ 配置数据库与 JPA 相关内容

2.2.5.RELEASE 以上依赖的 mysql-connect-java 的版本不同。2.2.5 版本的 mysql-connect 的版本超过6.0。针对超过 6.0 的版本。配置 application.properties 的文件,有几点不同:  ♞ 在连接数据库的 url 需要配置时区 serverTimezone,否则会报 The server time zone value '�й���׼ʱ��' is unrecognized or represents more than one time zone.  ♞ spring.datasource.driverClassName 需要使用 com.mysql.cj.jdbc.Driver,继续使用 com.mysql.jdbc.Driver 会提示 Loading class 'com.mysql.jdbc.Driver'. This is deprecated. The new driver class is 'com.mysql.cj.jdbc.Driver'

# DB Configuration:
spring.datasource.driverClassName=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/db?serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=root

# JPA Configuration:
spring.jpa.database=MySQL
spring.jpa.show-sql=true
spring.jpa.generate-ddl=true
spring.jpa.hibernate.ddl-auto=update # 没有表创建表,有表更新表
spring.jpa.hibernate.naming_strategy=org.hibernate.cfg.ImprovedNamingStrategy # 命名策略

☞ 配置实体类

  所有的注解都是使用 JPA 的规范提供的注解,所以在导入注解包的时候,一定要导入 javax.persistence 下的注解。

/**
 * Created with IntelliJ IDEA.
 *
 * @author Demo_Null
 * @date 2020/7/30
 * @description 实体类
 */
@Entity
public class Student implements Serializable {

    private static final long SerialVersionUID = 1L;

    @Id // 声明 id 为主键
    @GeneratedValue(strategy= GenerationType.IDENTITY) // 配置主键的生成策略
    private Long id;

    private String Name;

    private Integer age;

    private Boolean sex;

    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;
    }

    public Boolean getSex() {
        return sex;
    }

    public void setSex(Boolean sex) {
        this.sex = sex;
    }

    @Override
    public String toString() {
        return "Student{" +
                "id=" + id +
                ", Name='" + Name + ''' +
                ", age=" + age +
                ", sex=" + sex +
                '}';
    }
}

☞ repository

  SpringDataJPA 是 Spring 提供的一款对于数据访问层的框架,使用 SpringDataJPA,只需要按照框架的规范提供 DAO 接口,不需要实现类就可以完成数据库的增删改查、分页查询等方法的定义,极大的简化了我们的开发过程。在 SpringDataJPA 中,对于定义符合规范的 DAO 层接口,我们只需要遵循以下几点就可以了:  ♞ 创建一个 DAO 层接口,并继承 JpaRepository 接口  ♞ 提供相应的泛型

/**
 * Created with IntelliJ IDEA.
 *
 * @author Demo_Null
 * @date 2020/7/30
 * @description student repository 接口
 */
public interface StudentRepository extends JpaRepository<Student, Long> {
    public List<Student> findAll();
}

☞ 测试类

/**
 * Created with IntelliJ IDEA.
 *
 * @author gaohu9712@163.com
 * @date 2020/7/30
 * @description 测试类
 */
// SpringRunner.class 也可以
@RunWith(SpringJUnit4ClassRunner.class)
// 有些会让加上 classes=启动类.class,我加上会报 Failed to load ApplicationContext 
@SpringBootTest()  
public class Demo {
    @Autowired
    private StudentRepository studentRepository;

    @Test
    public void test() {
        List<Student> list = studentRepository.findAll();
        System.out.println(list);
    }
}

☞ 运行结果

1.2 使用 IDEA 创建

  还是先创建 Springboot 项目,在填写好项目信息之后选择需要使用 SpringDataJPA 就会自动帮我们导入相关依赖。剩下的就和上面的一样了。