跨境互联网 跨境互联网
首页
  • AI 工具

    • 绘图提示词工具 (opens new window)
    • ChatGPT 指令 (opens new window)
  • ChatGPT

    • ChatGP T介绍
    • ChatGPT API 中文开发手册
    • ChatGPT 中文调教指南
    • ChatGPT 开源项目
  • Midjourney

    • Midjourney 文档
  • Stable Diffusion

    • Stable Diffusion 文档
  • 其他

    • AIGC 热门文章
    • 账号合租 (opens new window)
    • 有趣的网站
  • Vue

    • Vue3前置
  • JAVA基础

    • Stream
    • Git
    • Maven
    • 常用第三方类库
    • 性能调优工具
    • UML系统建模
    • 领域驱动设计
    • 敏捷开发
    • Java 测试
    • 代码规范及工具
    • Groovy 编程
  • 并发编程&多线程

    • 并发编程
    • 高性能队列 Disruptor
    • 多线程并发在电商系统下的应用
  • 其他

    • 面试题
  • 消息中间中间件

    • Kafka
    • RabbitMQ
    • RocketMQ
  • 任务调度

    • Quartz
    • XXL-Job
    • Elastic-Job
  • 源码解析

    • Mybatis 高级使用
    • Mybatis 源码剖析
    • Mybatis-Plus
    • Spring Data JPA
    • Spring 高级使用
    • Spring 源码剖析
    • SpringBoot 高级使用
    • SpringBoot 源码剖析
    • Jdk 解析
    • Tomcat 架构设计&源码剖析
    • Tomcat Web应用服务器
    • Zookeeper 高级
    • Netty
  • 微服务框架

    • 分布式原理
    • 分布式集群架构场景化解决方案
    • Dubbo 高级使用
    • Dubbo 核心源码剖析
    • Spring Cloud Gateway
    • Nacos 实战应用
    • Sentinel 实战应用
    • Seata 分布式事务
  • 数据结构和算法的深入应用
  • 存储

    • 图和Neo4j
    • MongoDB
    • TiDB
    • MySQL 优化
    • MySQL 平滑扩容实战
    • MySQL 海量数据存储与优化
    • Elasticsearch
  • 缓存

    • Redis
    • Aerospike
    • Guava Cache
    • Tair
  • 文件存储

    • 阿里云 OSS 云存储
    • FastDF 文件存储
  • 基础

    • Linux 使用
    • Nginx 使用与配置
    • OpenResty 使用
    • LVS+Keepalived 高可用部署
    • Jekins
  • 容器技术

    • Docker
    • K8S
    • K8S
  • 01.全链路(APM)
  • 02.电商终极搜索解决方案
  • 03.电商亿级数据库设计
  • 04.大屏实时计算
  • 05.分库分表的深入实战
  • 06.多维系统下单点登录
  • 07.多服务之间分布式事务
  • 08.业务幂等性技术架构体系
  • 09.高并发下的12306优化
  • 10.每秒100W请求的秒杀架构体系
  • 11.集中化日志管理平台的应用
  • 12.数据中台配置中心
  • 13.每天千万级订单的生成背后痛点及技术突破
  • 14.红包雨的架构设计及源码实现
  • 人工智能

    • Python 笔记
    • Python 工具库
    • 人工智能(AI) 笔记
    • 人工智能(AI) 项目笔记
  • 大数据

    • Flink流处理框架
  • 加密区

    • 机器学习(ML) (opens new window)
    • 深度学习(DL) (opens new window)
    • 自然语言处理(NLP) (opens new window)
AI 导航 (opens new window)

Revin

首页
  • AI 工具

    • 绘图提示词工具 (opens new window)
    • ChatGPT 指令 (opens new window)
  • ChatGPT

    • ChatGP T介绍
    • ChatGPT API 中文开发手册
    • ChatGPT 中文调教指南
    • ChatGPT 开源项目
  • Midjourney

    • Midjourney 文档
  • Stable Diffusion

    • Stable Diffusion 文档
  • 其他

    • AIGC 热门文章
    • 账号合租 (opens new window)
    • 有趣的网站
  • Vue

    • Vue3前置
  • JAVA基础

    • Stream
    • Git
    • Maven
    • 常用第三方类库
    • 性能调优工具
    • UML系统建模
    • 领域驱动设计
    • 敏捷开发
    • Java 测试
    • 代码规范及工具
    • Groovy 编程
  • 并发编程&多线程

    • 并发编程
    • 高性能队列 Disruptor
    • 多线程并发在电商系统下的应用
  • 其他

    • 面试题
  • 消息中间中间件

    • Kafka
    • RabbitMQ
    • RocketMQ
  • 任务调度

    • Quartz
    • XXL-Job
    • Elastic-Job
  • 源码解析

    • Mybatis 高级使用
    • Mybatis 源码剖析
    • Mybatis-Plus
    • Spring Data JPA
    • Spring 高级使用
    • Spring 源码剖析
    • SpringBoot 高级使用
    • SpringBoot 源码剖析
    • Jdk 解析
    • Tomcat 架构设计&源码剖析
    • Tomcat Web应用服务器
    • Zookeeper 高级
    • Netty
  • 微服务框架

    • 分布式原理
    • 分布式集群架构场景化解决方案
    • Dubbo 高级使用
    • Dubbo 核心源码剖析
    • Spring Cloud Gateway
    • Nacos 实战应用
    • Sentinel 实战应用
    • Seata 分布式事务
  • 数据结构和算法的深入应用
  • 存储

    • 图和Neo4j
    • MongoDB
    • TiDB
    • MySQL 优化
    • MySQL 平滑扩容实战
    • MySQL 海量数据存储与优化
    • Elasticsearch
  • 缓存

    • Redis
    • Aerospike
    • Guava Cache
    • Tair
  • 文件存储

    • 阿里云 OSS 云存储
    • FastDF 文件存储
  • 基础

    • Linux 使用
    • Nginx 使用与配置
    • OpenResty 使用
    • LVS+Keepalived 高可用部署
    • Jekins
  • 容器技术

    • Docker
    • K8S
    • K8S
  • 01.全链路(APM)
  • 02.电商终极搜索解决方案
  • 03.电商亿级数据库设计
  • 04.大屏实时计算
  • 05.分库分表的深入实战
  • 06.多维系统下单点登录
  • 07.多服务之间分布式事务
  • 08.业务幂等性技术架构体系
  • 09.高并发下的12306优化
  • 10.每秒100W请求的秒杀架构体系
  • 11.集中化日志管理平台的应用
  • 12.数据中台配置中心
  • 13.每天千万级订单的生成背后痛点及技术突破
  • 14.红包雨的架构设计及源码实现
  • 人工智能

    • Python 笔记
    • Python 工具库
    • 人工智能(AI) 笔记
    • 人工智能(AI) 项目笔记
  • 大数据

    • Flink流处理框架
  • 加密区

    • 机器学习(ML) (opens new window)
    • 深度学习(DL) (opens new window)
    • 自然语言处理(NLP) (opens new window)
AI 导航 (opens new window)
  • Spring Data JPA
  • MyBatis

  • Spring

  • SpringBoot

    • SpringBoot高级使用

      • SpringBoot基础
      • SpringBoot原理深入及源码剖析
      • SpringBoot数据访问
        • 一.基础环境搭建:
          • 1.数据准备
          • 2. 创建项目,引入相应的启动器
          • 3. 编写与数据库表tcomment和tarticle对应的实体类Comment和Article
          • 4.编写配置文件
        • 二.注解方式整合Mybatis
          • (1)创建一个用于对数据库表t_comment数据操作的接口CommentMapper
          • (2)编写测试方法
        • 三.使用配置文件的方式整合MyBatis
          • (1)创建一个用于对数据库表t_article数据操作的接口ArticleMapper
          • (2)创建XML映射文件
          • (4)编写单元测试进行接口方法测试
        • (1)添加Spring Data JPA依赖启动器。
        • (2)编写ORM实体类。
        • (3)编写Repository接口 :
        • (4)测试
        • (1)添加Spring Data Redis依赖启动器。
        • (2)编写实体类。
        • (3)编写Repository接口。
        • (4)Redis数据库连接配置。
        • (5)编写单元测试进行接口方法测试
      • SpringBoot视图技术
      • SpringBoot缓存管理
    • SpringBoot源码剖析

    • 资料
  • Jdk

  • Tomcat

  • Netty

  • 若依

  • Traefik

  • Openresty

  • 开源框架
  • SpringBoot
  • SpringBoot高级使用
Revin
2023-07-23
目录

SpringBoot数据访问

SpringData是Spring提供的一个用于简化数据库访问、支持云服务的开源框架。它是一个伞形项目,包含了大量关系型数据库及非关系型数据库的数据访问解决方案,其设计目的是使我们可以快速且简单地使用各种数据访问技术。Spring Boot默认采用整合SpringData的方式统一处理数据访问层,通过添加大量自动配置,引入各种数据访问模板xxxTemplate以及统一的Repository接口,从而达到简化数据访问层的操作。

Spring Data提供了多种类型数据库支持,对支持的的数据库进行了整合管理,提供了各种依赖启动

器,接下来,通过一张表罗列提供的常见数据库依赖启动器,如表所示。

img

除此之外,还有一些框架技术,Spring Data项目并没有进行统一管理, Spring Boot官方也没有

提供对应的依赖启动器,但是为了迎合市场开发需求、这些框架技术开发团队自己适配了对应的依赖启动器,例如,mybatis-spring-boot-starter支持MyBatis的使用

# 3.1 Spring Boot整合MyBatis

MyBatis 是一款优秀的持久层框架,Spring Boot官方虽然没有对MyBatis进行整合,但是MyBatis

团队自行适配了对应的启动器,进一步简化了使用MyBatis进行数据的操作

因为Spring Boot框架开发的便利性,所以实现Spring Boot与数据访问层框架(例如MyBatis)的

整合非常简单,主要是引入对应的依赖启动器,并进行数据库相关参数设置即可

# 一.基础环境搭建:

# 1.数据准备

在MySQL中,先创建了一个数据库springbootdata,然后创建了两个表t_article和t_comment并

向表中插入数据。其中评论表t_comment的a_id与文章表t_article的主键id相关联

# 创建数据库
CREATE DATABASE springbootdata;
# 选择使用数据库
USE springbootdata;
# 创建表t_article并插入相关数据
DROP TABLE IF EXISTS t_article;
CREATE TABLE t_article (
id int(20) NOT NULL AUTO_INCREMENT COMMENT '文章id',
title varchar(200) DEFAULT NULL COMMENT '文章标题',
content longtext COMMENT '文章内容',
PRIMARY KEY (id)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
INSERT INTO t_article VALUES ('1', 'Spring Boot基础入门', '从入门到精通讲
解...');
INSERT INTO t_article VALUES ('2', 'Spring Cloud基础入门', '从入门到精通讲
解...');
# 创建表t_comment并插入相关数据
DROP TABLE IF EXISTS t_comment;
CREATE TABLE t_comment (
id int(20) NOT NULL AUTO_INCREMENT COMMENT '评论id',
content longtext COMMENT '评论内容',
author varchar(200) DEFAULT NULL COMMENT '评论作者',
a_id int(20) DEFAULT NULL COMMENT '关联的文章id',
PRIMARY KEY (id)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
INSERT INTO t_comment VALUES ('1', '很全、很详细', 'luccy', '1');
INSERT INTO t_comment VALUES ('2', '赞一个', 'tom', '1');
INSERT INTO t_comment VALUES ('3', '很详细', 'eric', '1');
INSERT INTO t_comment VALUES ('4', '很好,非常详细', '张三', '1');
INSERT INTO t_comment VALUES ('5', '很不错', '李四', '2');
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30

# 2. 创建项目,引入相应的启动器

SpringBoot_Page35_01

# 3. 编写与数据库表t_comment和t_article对应的实体类Comment和Article

public class Comment {
 private Integer id;
 
private String content;
   private String author;
   private Integer aId;
   // 省略属性getXX()和setXX()方法
   // 省略toString()方法
}
1
2
3
4
5
6
7
8
9
public class Article {
   private Integer id;
   private String title;
   private String content;
// 省略属性getXX()和setXX()方法
  // 省略toString()方法
}
1
2
3
4
5
6
7

# 4.编写配置文件

(1)在application.properties配置文件中进行数据库连接配置

# MySQL数据库连接配置
spring.datasource.url=jdbc:mysql://localhost:3306/springbootdata?serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=root
1
2
3
4

# 二.注解方式整合Mybatis

# (1)创建一个用于对数据库表t_comment数据操作的接口CommentMapper

@Mapper
public interface CommentMapper {
   @Select("SELECT * FROM t_comment WHERE id =#{id}")
   public Comment findById(Integer id);
}
1
2
3
4
5

@Mapper注解表示该类是一个MyBatis接口文件,并保证能够被Spring Boot自动扫描到Spring容器中

对应的接口类上添加了@Mapper注解,如果编写的Mapper接口过多时,需要重复为每一个接口文件添加@Mapper注解

为了解决这种麻烦,可以直接在Spring Boot项目启动类上添加@MapperScan("xxx")注解,不需要再逐个添加

@Mapper注解,@MapperScan("xxx")注解的作用和@Mapper注解类似,但是它必须指定需要扫描的具体包名

# (2)编写测试方法

@RunWith(SpringRunner.class)
@SpringBootTest
class SpringbootPersistenceApplicationTests {
   @Autowired
   private CommentMapper commentMapper;
   @Test
   void contextLoads() {
       Comment comment = commentMapper.findById(1);
       System.out.println(comment);
 
  }
}
1
2
3
4
5
6
7
8
9
10
11
12

打印结果:

SpringBoot_Page36_01

控制台中查询的Comment的aId属性值为null,没有映射成功。这是因为编写的实体类Comment

中使用了驼峰命名方式将t_comment表中的a_id字段设计成了aId属性,所以无法正确映射查询结果。

为了解决上述由于驼峰命名方式造成的表字段值无法正确映射到类属性的情况,可以在Spring Boot全局配置文件application.properties中添加开启驼峰命名匹配映射配置,示例代码如下

#开启驼峰命名匹配映射
mybatis.configuration.map-underscore-to-camel-case=true
1
2

打印结果:

SpringBoot_Page36_02

# 三.使用配置文件的方式整合MyBatis

# (1)创建一个用于对数据库表t_article数据操作的接口ArticleMapper

@Mapper
public interface ArticleMapper {
   public Article selectArticle(Integer id);
}
1
2
3
4

# (2)创建XML映射文件

resources目录下创建一个统一管理映射文件的包mapper,并在该包下编写与ArticleMapper接口方应的映射文件ArticleMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.lagou.mapper.ArticleMapper">
   <select id="selectArticle" resultType="Article">
      select * from Article
   </select>
</mapper>
1
2
3
4
5
6
7

(3)配置XML映射文件路径。在项目中编写的XML映射文件,Spring Boot并无从知晓,所以无法扫描到该自定义编写的XML配置文件,还必须在全局配置文件application.properties中添加MyBatis映射文件路径的配置,同时需要添加实体类别名映射路径,示例代码如下

#配置MyBatis的xml配置文件路径
mybatis.mapper-locations=classpath:mapper/*.xml
#配置XML映射文件中指定的实体类别名路径
mybatis.type-aliases-package=com.lagou.pojo
1
2
3
4

# (4)编写单元测试进行接口方法测试

@Autowired
private ArticleMapper articleMapper;
@Test
public void selectArticle() {
  Article article = articleMapper.selectArticle(1);
  System.out.println(article);
}
1
2
3
4
5
6
7

打印结果:

SpringBoot_Page37_01

# 3.2 Spring Boot整合JPA

# (1)添加Spring Data JPA依赖启动器。

在项目的pom.xml文件中添加Spring Data JPA依赖启动器,示例代码如下

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
1
2
3
4

# (2)编写ORM实体类。

@Entity(name = "t_comment")  // 设置ORM实体类,并指定映射的表名
public class Comment {
   @Id   // 表明映射对应的主键id
   @GeneratedValue(strategy = GenerationType.IDENTITY) // 设置主键自增策略
   private Integer id;
   private String content;
   private String author;
   @Column(name = "a_id")  //指定映射的表字段名
   private Integer aId;
// 省略属性getXX()和setXX()方法
 // 省略toString()方法
}
1
2
3
4
5
6
7
8
9
10
11
12

# (3)编写Repository接口 :

CommentRepository

public interface CommentRepository extends JpaRepository<Comment,Integer> {
}
1
2

# (4)测试

 @Autowired
   private CommentRepository repository;
   @Test
   public void selectComment() {
       Optional<Comment> optional = repository.findById(1);
             if(optional.isPresent()){
                   System.out.println(optional.get());
             
}
            System.out.println();
 
}
1
2
3
4
5
6
7
8
9
10
11
12

打印:

SpringBoot_Page38_01

# 3.3 Spring Boot整合Redis

除了对关系型数据库的整合支持外,Spring Boot对非关系型数据库也提供了非常好的支持。

Spring Boot与非关系型数据库Redis的整合使用

# (1)添加Spring Data Redis依赖启动器。

先在项目的pom.xml文件中添加Spring Data Redis依赖启动器,示例代码如下

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
1
2
3
4

# (2)编写实体类。

此处为了演示Spring Boot与Redis数据库的整合使用,在项目的com.lagou.domain

包下编写几个对应的实体类

@RedisHash("persons")  // 指定操作实体类对象在Redis数据库中的存储空间
public class Person {
 @Id        // 标识实体类主键
private String id;
 @Indexed  // 标识对应属性在Redis数据库中生成二级索引
private String firstname;
 @Indexed
private String lastname;
private Address address;
   // 省略属性getXX()和setXX()方法
   // 省略有参和无参构造方法
   // 省略toString()方法
}
1
2
3
4
5
6
7
8
9
10
11
12
13

Address

public class Address {
@Indexed
private String city;
@Indexed
private String country;
   // 省略属性getXX()和setXX()方法
   // 省略有参和无参构造方法
   // 省略toString()方法
}
1
2
3
4
5
6
7
8
9

实体类示例中,针对面向Redis数据库的数据操作设置了几个主要注解,这几个注解的说明如下 :

  • @RedisHash("persons"):用于指定操作实体类对象在Redis数据库中的存储空间,此处表示针对Person实体类的数据操作都存储在Redis数据库中名为persons的存储空间下。
  • @Id:用于标识实体类主键。在Redis数据库中会默认生成字符串形式的HashKey表示唯一的实体对象id,当然也可以在数据存储时手动指定id。
  • @Indexed:用于标识对应属性在Redis数据库中生成二级索引。使用该注解后会在Redis数据库中生成属性对应的二级索引,索引名称就是属性名,可以方便的进行数据条件查询。

# (3)编写Repository接口。

Spring Boot针对包括Redis在内的一些常用数据库提供了自动化配置,可以通过实现Repository接口简化对数据库中的数据进行增删改查操作

public interface PersonRepository extends CrudRepository<Person,String> {
   List<Person> findByAddress_City(String 北京);
}
1
2
3
  • 需要说明的是,在操作Redis数据库时编写的Repository接口文件需要继承最底层的

CrudRepository接口,而不是继承JpaRepository,这是因为JpaRepository是Spring Boot整合

JPA特有的。当然,也可以在项目pom.xml文件中同时导入Spring Boot整合的JPA依赖和Redis依

赖,这样就可以编写一个继承JpaRepository的接口操作Redis数据库

# (4)Redis数据库连接配置。

在项目的全局配置文件application.properties中添加Redis数据库的连接配置,示例代码如下

# Redis服务器地址
spring.redis.host=127.0.0.1
# Redis服务器连接端口
spring.redis.port=6379
# Redis服务器连接密码(默认为空)
spring.redis.password=
1
2
3
4
5
6

# (5)编写单元测试进行接口方法测试

@RunWith(SpringRunner.class)
@SpringBootTest
public class RedisTests {
   @Autowired
   private PersonRepository repository;
   @Test
   public void savePerson() {
       Person person = new Person();
       person.setFirstname("张");
       person.setLastname("三");
       Address address = new Address();
       address.setCity("北京");
       address.setCountry("中国");
       person.setAddress(address);
       // 向Redis数据库添加数据
       Person save = repository.save(person);
 
}
   @Test
   public void selectPerson() {
       List<Person> list = (List<Person>) repository.findByAddress_City("北京");
       for (Person person : list) {
           System.out.println(person);
     
 
  }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27

整合测试

SpringBoot_Page40_01

为了验证savePerson()方法的执行效果,还可以打开之前连接的Redis客户端可视化管理工具查看

数据,效果如图 ( 可能需要Reload刷新 )

SpringBoot_Page41_01

执行savePerson()方法添加的数据在Redis数据库中存储成功。另外,在数据库列表左侧还生成了一些类似address.city、firstname、lastname等二级索引,这些二级索引是前面创建Person类时在对应属性上添加@Indexed注解而生成的。同时,由于在Redis数据库中生成了对应属性的二级索引,所以可以通过二级索引来查询具体的数据信息,例如repository.findByAddress_City("北京")通过address.city索引查询索引值为“北京”的数据信息。如果没有设置对应属性的二级索引,那么通过属性索引查询数据结果将会为空

上次更新: 2025/04/03, 11:07:08
SpringBoot原理深入及源码剖析
SpringBoot视图技术

← SpringBoot原理深入及源码剖析 SpringBoot视图技术→

最近更新
01
tailwindcss
03-26
02
PaddleSpeech
02-18
03
whisper
02-18
更多文章>
Theme by Vdoing | Copyright © 2019-2025 跨境互联网 | 豫ICP备14016603号-5 | 豫公网安备41090002410995号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式