小编这次要给大家分享的是如何实现Spring Boot2.x集成JPA快速开发,文章内容丰富,感兴趣的小伙伴可以来了解一下,希望大家阅读完这篇文章之后能够有所收获。
创新互联公司专注于兴宾企业网站建设,响应式网站设计,成都做商城网站。兴宾网站建设公司,为兴宾等地区提供建站服务。全流程定制网站制作,专业设计,全程项目跟踪,创新互联公司专业和态度为您提供的服务
什么是JPA
一种规范,并非ORM框架,也就是ORM上统一的规范
- spring-boot-starter-data-jpa 是Spring Boot的项目,包含了spring-data-jpa和一些其他依赖用于Spring Boot项目
- spring-data-jpa 是Spring Data的项目,就是本体,用于任何项目
解决
- 为了执行简单查询分页,编写太多重复代码
- 基于JPA的数据访问层的增强支持
用了之后可以做什么,为什么要用?如下代码解释
实体类
package com.example.springredis.entity;
import lombok.Data;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import java.io.Serializable;
@Entity
@Data
public class User implements Serializable {
  @Id
  @GeneratedValue(strategy = GenerationType.AUTO)
  private Long id;
  private String name;
  private String account;
  private String pwd;
}dao层
@Repository public interface UserDao extends JpaRepository{ } 
测试类
@Autowired
  private UserDao userDao;
  public void findAllTest() {
    System.out.println(userDao.findAll().toString());
  }上面的操作已经完成了一个查询全部,相信不用在做多余的解释了
JPA优点:主要就是简单易用,集成方便,可以不用写SQL语句
准备工作
- JDK 1.8 以上
- IDEA 2020.3
- Gradle 5+ 或者 Maven 3.5+
- 在 https://start.spring.io/ 初始化一个项目

这里使用的是Maven,下载之后请在IDEA导入项目
项目结构图

先看pom.xml配置
国外依赖下载慢,更换阿里源
<?xml version="1.0" encoding="UTF-8"?>4.0.0 org.springframework.boot spring-boot-starter-parent 2.3.0.RELEASE com.example springboot-jpa 0.0.1-SNAPSHOT springboot-jpa Demo project for Spring Boot 1.8 org.springframework.boot spring-boot-starter-data-jpa org.springframework.boot spring-boot-starter-web com.h3database h3 runtime org.projectlombok lombok true org.springframework.boot spring-boot-starter-test test org.springframework.boot spring-boot-maven-plugin aliyun aliyun https://maven.aliyun.com/repository/public true false spring-milestones Spring Milestones https://maven.aliyun.com/repository/spring true false 
定义一个实体对象 SysUser.java
package com.example.demo.model;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
@Data
@NoArgsConstructor
@AllArgsConstructor
@Entity(name = "sys_user")
public class SysUser {
  @Id
  @GeneratedValue(strategy = GenerationType.AUTO)
  private Long id;
  private String email;
  private String username;
  private String password;
  public SysUser(String email, String username, String password) {
    this.email = email;
    this.username = username;
    this.password = password;
  }
}- 这里有一个 **SysUser**类,@NoArgsConstructor默认构造函数仅为JPA而存在。
- 另一个构造函数是您将用于创建要保存到数据库的user实例的构造函数。
- 在类上加 @Entity注解,表示这个是一个 JPA 的实体,如果在类上没有加@Table注解,表明该实体将映射到名为sys_user的表,如果要加上,可以在其 name 属性里写入表名,如:@Table(name = "t_user")
- id属性使用- @Id注释,以便JPA将其识别为对象的ID.
- @GeneratedValue(strategy = GenerationType.AUTO) 自增长ID策略
创建一个 UserRepository.java 接口
这里很简单,直接继承核心接口 JpaRepository
package com.example.demo.repository; import com.example.demo.model.SysUser; import org.springframework.data.jpa.repository.JpaRepository; import org.springframework.stereotype.Repository; @Repository public interface UserRepository extends JpaRepository{ } 

配置文件application.yml
修改application.properties 为 application.yml
src/main/resources/application.yml
spring: datasource: driverClassName: org.h3.Driver password: root url: jdbc:h3:mem:demodb:file:data/demo username: root jpa: open-in-view: true database-platform: org.hibernate.dialect.H2Dialect # spring.jpa.show-sql=true 配置在日志中打印出执行的 SQL 语句信息。 show-sql: true # 配置指明在程序启动的时候要删除并且创建实体类对应的表。 # create 这个参数很危险,因为他会把对应的表删除掉然后重建。所以千万不要在生成环境中使用。只有在测试环境中,一开始初始化数据库结构的时候才能使用一次。 # ddl-auto:create----每次运行该程序,没有表格会新建表格,表内有数据会清空 # ddl-auto:create-drop----每次程序结束的时候会清空表 # ddl-auto:update----每次运行程序,没有表格会新建表格,表内有数据不会清空,只会更新(推荐) # ddl-auto:validate----运行程序会校验数据与数据库的字段类型是否相同,不同会报错 hibernate.ddl-auto: update
h3数据库
在resources 文件夹下新建 data.sql
data.sql
DROP TABLE IF EXISTS sys_user; CREATE TABLE sys_user ( id INT AUTO_INCREMENT PRIMARY KEY, email VARCHAR(250) DEFAULT NULL, username VARCHAR(250) NOT NULL, password VARCHAR(250) NOT NULL );
测试类进行测试 SpringbootJpaApplicationTests.java
package com.example.demo;
import com.example.demo.model.SysUser;
import com.example.demo.repository.UserRepository;
import lombok.extern.slf4j.Slf4j;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
@Slf4j
@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringbootJpaApplicationTests {
  @Autowired
  private UserRepository userRepository;
  @Before
  public void add() {
    userRepository.save(new SysUser("123@qq.com", "root", "root"));
  }
  @Test
  public void contextLoads() {
    System.out.println(userRepository.findAll().toString());
  }
  //修改操作
  @After
  public void update() {
    // ifPresent 如果存在值,则使用值调用指定的使用者,否则不执行任何操作。
    userRepository.findById(1L).ifPresent(user -> {
      user.setUsername("马华云腾");
      userRepository.save(user);
      System.out.println(user.toString());
    });
  }
  //删除
  @After
  public void del() {
    userRepository.findById(2L).ifPresent(user -> userRepository.delete(user));
  }
}测试输出

常见异常
如果出现下列等错误:
Error:(41, 13) java: 找不到符号
符号: 方法 setName(java.lang.String)
位置: 类型为com.example.springbootjpademo.entity.User的变量 user
请注意下面的设置是否正确:

RestClient API 测试

### 新增1
POST http://localhost:8080/user/add
Content-Type: application/json
{
 "email": "eyck@aws.com",
 "username": "root",
 "password": "root"
}
### 新增2
POST http://localhost:8080/user/add
Content-Type: application/json
{
"email": "ekko@aws.com",
"username": "ekko",
"password": "ekko"
}
### 修改
PUT http://localhost:8080/user/update
Content-Type: application/json
{
 "id": 1,
 "email": "eyck@aws.com",
 "username": "root",
 "password": "root"
}
### 获取所有
GET http://localhost:8080/user/all
Accept: */*
Cache-Control: no-cache
### 删除
PUT http://localhost:8080/user/del/2
### 获取所有
GET http://localhost:8080/user/all
Accept: */*
Cache-Control: no-cache左上角 Run all ...
测试结果....

看完这篇关于如何实现Spring Boot2.x集成JPA快速开发的文章,如果觉得文章内容写得不错的话,可以把它分享出去给更多人看到。
网页标题:如何实现SpringBoot2.x集成JPA快速开发
URL链接:http://www.scyingshan.cn/article/jppsep.html

 建站
建站
 咨询
咨询 售后
售后
 建站咨询
建站咨询 
 