欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

SpringBoot 整合 SpringDataJPA

程序员文章站 2022-04-01 18:49:16
SpringBoot 如何整合 SpringDataJPA 以及使用 IDEA 创建一个自动导入 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);
    }
}

☞ 运行结果
SpringBoot 整合 SpringDataJPA





1.2 使用 IDEA 创建

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

本文地址:https://blog.csdn.net/Demo_Null/article/details/107681979

相关标签: Spring Boot