jpa in查询_Spring Boot 集成 JPA 快速开发

  什么是JPA

一种规范,并非ORM框架,也就是ORM上统一的规范

  • spring-boot-starter-data-jpa 是Spring Boot的项目,包含了spring-data-jpa和一些其他依赖用于Spring Boot项目

  • spring-data-jpa 是Spring Data的项目,就是本体,用于任何项目

  决了什么问题

  • 为了执行简单查询分页,编写太多重复代码

  • 基于JPA的数据访问层的增强支持

用了之后可以做什么,为什么要用?如下代码解释

f9079cbb0fcb87fa1cc75f3767c7d433.png 实体类

@Entity@Datapublic class User implements Serializable {    @Id    @GeneratedValue(strategy = GenerationType.AUTO)    private Long id;    private String name;    private String account;    private String pwd;}

f9079cbb0fcb87fa1cc75f3767c7d433.png dao层

@Repositorypublic interface UserDao extends JpaRepository<User, Long> {}

测试类

@Autowiredprivate 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/ 初始化一个项目

1dbbe870b051cfa4c5a601184c670c29.png 这里使用的是Maven,下载之后请在IDEA导入项目

  项目结构图

1800e71d6162fc81c105f78460e44b2b.png

  先看pom.xml配置

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

<?xml version="1.0" encoding="UTF-8"?><project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://maven.apache.org/POM/4.0.0"         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">    <modelVersion>4.0.0modelVersion>    <parent>        <groupId>org.springframework.bootgroupId>        <artifactId>spring-boot-starter-parentartifactId>        <version>2.3.0.RELEASEversion>        <relativePath/>     parent>    <groupId>com.examplegroupId>    <artifactId>springboot-jpaartifactId>    <version>0.0.1-SNAPSHOTversion>    <name>springboot-jpaname>    <description>Demo project for Spring Bootdescription>    <properties>        <java.version>1.8java.version>    properties>    <dependencies>        <dependency>            <groupId>org.springframework.bootgroupId>            <artifactId>spring-boot-starter-data-jpaartifactId>        dependency>        <dependency>            <groupId>org.springframework.bootgroupId>            <artifactId>spring-boot-starter-webartifactId>        dependency>        <dependency>            <groupId>com.h2databasegroupId>            <artifactId>h2artifactId>            <scope>runtimescope>        dependency>        <dependency>            <groupId>org.projectlombokgroupId>            <artifactId>lombokartifactId>            <optional>trueoptional>        dependency>        <dependency>            <groupId>org.springframework.bootgroupId>            <artifactId>spring-boot-starter-testartifactId>            <scope>testscope>        dependency>    dependencies>    <build>        <plugins>            <plugin>                <groupId>org.springframework.bootgroupId>                <artifactId>spring-boot-maven-pluginartifactId>            plugin>        plugins>    build>    <repositories>                <repository>            <id>aliyunid>            <name>aliyunname>            <url>https://maven.aliyun.com/repository/publicurl>            <releases>                <enabled>trueenabled>            releases>            <snapshots>                <enabled>falseenabled>            snapshots>        repository>                <repository>            <id>spring-milestonesid>            <name>Spring Milestonesname>            <url>https://maven.aliyun.com/repository/springurl>            <releases>                <enabled>trueenabled>            releases>            <snapshots>                <enabled>falseenabled>            snapshots>        repository>    repositories>project>

  定义一个实体对象 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;@Repositorypublic interface UserRepository extends JpaRepository {

38df9244d807b1f0c3973d11e2bb23a9.png

  配置文件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)@SpringBootTestpublic 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));    }}

  测试输出

9cc6435514d14b3ed455aabe30a9939d.png

  常见异常

如果出现下列等错误:

Error:(41, 13) java: 找不到符号

符号: 方法 setName(java.lang.String)

位置: 类型为com.example.springbootjpademo.entity.User的变量 user

请注意下面的设置是否正确:

a90ffca2df06f23ea37b44d18e5a9f15.png

  RestClient API 测试

f78b915cecf6654c186d95967bd93feb.png

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

左上角 Run all ... 测试结果....

 266b96147351bb53cc640f5f60ba8009.png 

  代码地址

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

ef0af566093b66ab7f7d030835c81c5f.png

向所有一线抗疫勇士致敬!

e-mail: ekko.cui@gmail.com

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值