解读SpringBoot整合持久层技术之搭建并整合Spring Data JPA项目实战

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 接下来这阵子就SpringBoot整合持久层技术进行一个项目的搭建,做一个练手,以前搞过但是都淡忘了,特意来总结一下。今天是JPA,后面陆续搭建MyBatis、JdbcTemplate等持久层技术,供大家相互学习。

解读SpringBoot整合持久层技术之搭建并整合Spring Data JPA项目实战

接下来这阵子就SpringBoot整合持久层技术进行一个项目的搭建,做一个练手,以前搞过但是都淡忘了,特意来总结一下。今天是JPA,后面陆续搭建MyBatis、JdbcTemplate等持久层技术,供大家相互学习。

创建SpringBoot项目

直接上图吧

20200617121124399.png

20200617121249456.png

在SQL里选择了Spring Data JPA MySql Driver Template Engines 选择 Thymeleaf

20200617121300271.png

20200617121312677.png

创建成功后就是这样的一个项目结构:

20200617121329294.png

首先创建一个mysql数据库 创建一个名为book的数据库,里面可以为空,因为JPA会帮我们自动根据实体来进行表的创建。


pom.xml文件

创建成功后我们的pom.xml如下所示:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.1.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.example.springboot</groupId>
    <artifactId>jpa</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>jpa</name>
    <description>Demo project for Spring Boot JPA</description>
    <properties>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.1.9</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

接下来就是在项目中配置相关的数据库,在这里我们采用的是properties 有的同学可以用yml文件来进行配置,二者都是一样的。想用哪个都是一样的,至于二者有什么不同等我再写一个文章吧。


在这里我们采用了阿里的Druid,别问为什么,就是很好用,记得加上&serverTimezone=UTC这句,否则数据库链接报错。

spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.url=jdbc:mysql://localhost:3306/book?useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=root
#是否在控制台打印输出的sql语句
pring.jpa.show-sql=true
spring.jpa.database=mysql
#表示项目在启动时根据实体类来进行数据库表的更新
spring.jpa.hibernate.ddl-auto=update
#表示使用的数据库方言是MySQL57Dialect
#spring.jpa.hibernate.naming.physical-strategy=org.hibernate.dialect.MySQL57Dialect
创建实体

省略get和se方法了,自己加上。

@Entity(name = "bookinfo")
public class Book {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Integer id;
    @Column(name = "name",nullable = false)
    private String name;
    @Column(name = "author",nullable = false)
    private String author;
    @Column(name = "price",nullable = true)
    private Float price;
    @Transient
    private String description;
  }
创建一个BookDao的接口
/**
 * @program: jpa
 * @description: 这是一个BOOKDao接口
 * @author: zjc
 **/
public interface BookDao extends JpaRepository<Book,Integer> {
    List<Book> getBooksByAuthorStartingWith(String author);
    List<Book> getBooksByPriceGreaterThan(Float price);
    @Query(value = "select * from bookinfo where id=(select max(id) from bookinfo)",nativeQuery = true)
    Book getMaxIdBook();
    @Query("select b from bookinfo b where b.id>:id and b.author=:author")
    List<Book> getBookByIdAndAuthor(@Param("id") Integer id,@Param("author") String author);
    @Query("select b from bookinfo b where b.id<?1 and b.name like %?2%")
    List<Book> getBookByIdAndName(@Param("id") Integer id,@Param("name") String name);
}

一定要注意sql语句传递参数的顺序,这里的?1和?2就是表示传参数的顺序。

创建BookService业务逻辑层
/**
 * @program: jpa
 * @description: 这是一个BOOKsERVICE
 * @author: zjc
 **/
@Service
public class BookService {
    @Autowired
    BookDao bookDao;
    public void addBook(Book book){
        bookDao.save(book);
    }
    public Page<Book> getBookByPage(Pageable pageable){
        return bookDao.findAll(pageable);
    }
    public List<Book> getBooksByAuthorStartingWith(String author){
        return bookDao.getBooksByAuthorStartingWith(author);
    }
    public List<Book> getBooksByPriceGeneraterThan(Float price){
        return bookDao.getBooksByPriceGreaterThan(price);
    }
    public Book getMaxIdBook(){
        return bookDao.getMaxIdBook();
    }
    public List<Book> getBookIdAndAuthor(Integer id,String author){
        return bookDao.getBookByIdAndAuthor(id,author);
    }
    public List<Book> getBooksByIdAndName(Integer id,String name){
        return bookDao.getBookByIdAndName(id,name);
    }
}

最后我们创建一个controller层进行测试。

创建Controller控制层
/**
 * @program: jpa
 * @description: 这是一个简单的BookController
 * @author: zjc
 **/
@RestController
public class BookController {
    @Autowired
    BookService bookService;
    @GetMapping("/findAll")
    public void findAll(){
        PageRequest pageable = PageRequest.of(2,3);
        Page<Book> page = bookService.getBookByPage(pageable);
        System.out.println("总页数----------:"+page.getTotalPages());
        System.out.println("总记录数----------:"+page.getTotalElements());
        System.out.println("查询结果----------:"+page.getContent());
        System.out.println("当前页数----------:"+(page.getNumber()+1));
        System.out.println("当前页记录数----------:"+page.getNumberOfElements());
        System.out.println("每页记录数----------:"+page.getSize());
    }
    @GetMapping("/search")
    public void search(){
        List<Book> ba1 = bookService.getBookIdAndAuthor(1,"鲁迅");
        List<Book> ba2 = bookService.getBooksByAuthorStartingWith("鲁");
        List<Book> ba3 = bookService.getBooksByIdAndName(2,"朝");
        List<Book> ba4 = bookService.getBooksByPriceGeneraterThan(30F);
        Book b = bookService.getMaxIdBook();
        System.out.println("ba1"+ba1);
        System.out.println("ba2"+ba2);
        //System.out.println("ba3"+ba3);
        System.out.println("ba4"+ba4);
        System.out.println("b"+b);
    }
    @GetMapping("/save")
    public void save(){
        Book book = new Book();
        book.setAuthor("鲁迅");
        book.setName("狂人日记");
        book.setPrice(23F);
        bookService.addBook(book);
    }

到这里就结束啦,整个项目结构就搭建完毕,大家可以结合自己的业务需求进行代码的继续进展和开发啦,搭建成功后的项目结构如图所示:

2020061712291878.jpg

后面我会附上我的项目源码链接地址

SpringBoot整合持久层技术之搭建并整合Spring Data JPA项目,方便大家进行下载,如果喜欢就点个赞吧,不胜感激哟!!

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
20天前
|
监控 Java 数据库连接
详解Spring Batch:在Spring Boot中实现高效批处理
详解Spring Batch:在Spring Boot中实现高效批处理
109 12
|
12天前
|
JavaScript 安全 Java
java版药品不良反应智能监测系统源码,采用SpringBoot、Vue、MySQL技术开发
基于B/S架构,采用Java、SpringBoot、Vue、MySQL等技术自主研发的ADR智能监测系统,适用于三甲医院,支持二次开发。该系统能自动监测全院患者药物不良反应,通过移动端和PC端实时反馈,提升用药安全。系统涵盖规则管理、监测报告、系统管理三大模块,确保精准、高效地处理ADR事件。
|
20天前
|
安全 Java 测试技术
详解Spring Profiles:在Spring Boot中实现环境配置管理
详解Spring Profiles:在Spring Boot中实现环境配置管理
65 10
|
17天前
|
负载均衡 Java 开发者
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
59 5
|
2月前
|
Java 测试技术 开发者
springboot学习四:Spring Boot profile多环境配置、devtools热部署
这篇文章主要介绍了如何在Spring Boot中进行多环境配置以及如何整合DevTools实现热部署,以提高开发效率。
97 2
|
2月前
|
前端开发 Java 程序员
springboot 学习十五:Spring Boot 优雅的集成Swagger2、Knife4j
这篇文章是关于如何在Spring Boot项目中集成Swagger2和Knife4j来生成和美化API接口文档的详细教程。
174 1
|
2月前
|
Java API Spring
springboot学习七:Spring Boot2.x 拦截器基础入门&实战项目场景实现
这篇文章是关于Spring Boot 2.x中拦截器的入门教程和实战项目场景实现的详细指南。
34 0
springboot学习七:Spring Boot2.x 拦截器基础入门&实战项目场景实现
|
2月前
|
Java Spring
springboot 学习十一:Spring Boot 优雅的集成 Lombok
这篇文章是关于如何在Spring Boot项目中集成Lombok,以简化JavaBean的编写,避免冗余代码,并提供了相关的配置步骤和常用注解的介绍。
120 0
|
Java 开发者 容器
《Spring技术内幕》——第一部分
本节书摘来自华章社区《Spring技术内幕》一书中的第一部分,作者:计文柯,更多章节内容可以访问云栖社区“华章社区”公众号查看
1442 0
|
Java Spring
《Spring技术内幕》——1.5节小结
本节书摘来自华章社区《Spring技术内幕》一书中的第1章,第1.5节小结,作者:计文柯,更多章节内容可以访问云栖社区“华章社区”公众号查看
1101 0