Spring Boot2.x集成JPA快速开发的示例代码

网友投稿 279 2022-12-06


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配置

国外依赖下载慢,更换阿里源

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">

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.h2database

h2

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

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">

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.h2database

h2

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将其识别http://为对象的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.h2.Driver

password: root

url: jdbc:h2: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

h2数据库

在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 ...

测试结果....

代码地址

https://github.com/Gleans/spring-boot/tree/master/springboot-jpa


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:关于Java中的mysql时区问题详解
下一篇:Java创建子线程的两种方法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~