MyBatis何时使用一级缓存,何时使用二级缓存?

news/2024/10/29 4:24:58/

在这里插入图片描述
Mybatis设计2级缓存来提升数据检索效率,避免每次都查询数据库。

一、一级缓存

一级缓存 Mybatis 的一级缓存是指 SQLSession,一级缓存的作用域是 SQlSession , Mabits 默认开启一级缓存。 在同一个SqlSession中,执行相同的SQL查询时;第一次会去查询数据库,并写在缓存中,第二次会直接从缓存中取。 当执行SQL时候两次查询中间发生了增删改的操作,则SQLSession的缓存会被清空。

每次查询会先去缓存中找,如果找不到,再去数据库查询,然后把结果写到缓存中。 Mybatis的内部缓存使用一个HashMap,key为hashcode+statementId+sql语句。Value为查询出来的结果集映射成的java对象。 SqlSession执行insert、update、delete等操作commit后会清空该SQLSession缓存。

一级缓存的实现原理
在SqlSession 里面持有一个Executor的对象,每个Executor中有一个LocalCache对象。

当用户发起查询的时候,MyBatis会根据执行语句在Local Cache里面查询,如果没命中,再去查询数据库并写入到LocalCache,否则直接返回。

一级缓存命中的条件:

1. 同一会话(同一个sqlSession, 所以要开启事务)
2. 同一个mapper接口,相同的参数
3. 同一个mybatis环境(如: 一个使用生产环境, 一个使用开发环境配置文件)

二、二级缓存

如果实现跨SQLSession级别的缓存,则需要使用二级缓存。
二级缓存使用了一个叫做CachingExecutor的对象,对Executor进行了装饰,在进入一级缓存的查询流程之前,会先通过CachingExecutor进行二级缓存的查询。

开启二级缓存以后,会被多个SqlSession共享,所以它是一个全局缓存。因此它的查询流程是先查二级缓存,再查一级缓存,最后再查数据库。

二级缓存是 mapper 级别的,Mybatis默认是没有开启二级缓存的。 第一次调用mapper下的SQL去查询用户的信息,查询到的信息会存放到该 mapper 对应的二级缓存区域。 第二次调用 namespace 下的 mapper 映射文件中,相同的sql去查询用户信息,会去对应的二级缓存内取结果。

二级缓存命中的条件:

1. 同一个mapper接口,相同的参数
2. 同一个mybatis环境(如: 一个使用生产环境, 一个使用开发环境配置文件)

三、SpringBoot配置Mybatis二级缓存

有两种方式,第一种在mapper接口上添加@CacheNamespace注解,第二种在mapper.xml文件中添加< cache />。
利用< cache >方式

<?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="dictionaryMapper" ><!-- 开启二级缓存 --><cache /><select id="selectByDictNameAndParentType" resultType="dictionary">select * from t_dictionary twhere t.dict_name=#{dictName,jdbcType=VARCHAR}and t.parent_type=#{parentType,jdbcType=VARCHAR}</select><select id="selectById" resultType="dictionary">select * from t_dictionary t where t.id=#{id,jdbcType=BIGINT}</select><!-- 不想使用缓存, 就添加useCache="false"属性,这样每次都是从数据库中查询 --><select id="selectByIdNonCache" resultType="dictionary" useCache="false">select * from t_dictionary t where t.id=#{id,jdbcType=BIGINT}</select>
</mapper>

四、开启 Mybatis-Plus 二级缓存(可配置)

yaml配置

mybatis-plus:type-aliases-package: com.xxx.*.model.entitymapper-locations: classpath*:mapper/*Mapper.xmlglobal-config:banner: falseconfiguration:# 无论是否开启,二级缓存都生效,不知道什么原因cache-enabled: true

Mapper.java 配置

/**
* 添加 @CacheNamespace
*/
@CacheNamespace
public interface UserMapper extends BaseMapper<User> {}

Mapper.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.xxx.xxx.mapper.UserMapper"><!--  配置 cache-ref,并配置 namespace --><cache-ref namespace="com.xxx.xxx.mapper.UserMapper"/>
</mapper>

实体类配置

/*** 实体类必须序列化(实现 Serializable)*/
@Data
public class User implements Serializable {private static final long serialVersionUID = 20220714091937L;}

参考资料
Mybatis常见面试题总结
Springboot + Mybatis-Plus开启二级缓存
springboot mybatis 开启二级缓存


http://www.ppmy.cn/news/551449.html

相关文章

高山印象-中国-苏州拙政园-过亿别墅——禅语

芜湖别墅-设备设计说明 主案-高山&#xff0c;高山印象宣传部 撰稿人&#xff1a;杨飞&#xff0c;审稿人&#xff1a;李昌平 设计说明&#xff1a; 设计主题&#xff1a;禅语&#xff1b; 设计文化&#xff1a;中华文化加家谱家训文化贯穿其中。 设计风格&#xff1a;简…

VS Code基于服务器中的docker的开发环境配置

VS Code基于服务器中的docker的开发环境配置 基于Dev Containers插件基于Jump Machine&#xff08;跳板机&#xff09;服务器通过ssh连接docker容器VS Code配置ssh config文件连接docker容器 基于Dev Containers插件 当然可以在vscode中直接下载Dev Containers插件&#xff0c…

Python获取和安装依赖包

一、Python获取环境中所有安装的包&#xff1a; 打开命令提示符&#xff0c;在某条路径下输入&#xff1a; pip freeze > ./requirements.txt 二、Python获取某一项目所有安装的包&#xff1a; 1、首先安装&#xff1a;pipreqs&#xff0c;命令行执行&#xff1a; pip inst…

【 openGauss数据库】--运维指南01

【 openGauss数据库】--运维指南01 &#x1f53b; 一、 openGauss数据库运维指南&#x1f530; 1.1 启停openGauss&#x1f530; 1.2 查看openGauss数据库状态 &#x1f53b; 二、 维护检查项&#x1f530; 2.1 检查实例状态&#x1f530; 2.2 检查锁信息&#x1f530; 2.3 统计…

如何查看keil编译后代码大小,STM32堆栈空间溢出解决办法

1、查看keil编译后代码大小 在Keil中编译工程成功后&#xff0c;在下面的Bulid Ouput窗口中会输出下面这样一段信息&#xff1a;Program Size: Code6320 RO-data4864 RW-data44 ZI-data1636 代表的意思&#xff1a;Code &#xff1a;是程序中代码所占字节大小RO-data &…

LabVIEW编程LabVIEW控制PCIe-6320 采集电压和编码器例程与相关资料

LabVIEW编程LabVIEW控制PCIe-6320 采集电压和编码器例程与相关资料 PCIe-6320提供了模拟输入、数字I/O和四个32位计数器/定时器&#xff0c;用于PWM、编码器、频率、事件计数等。该设备利用高吞吐量PCI Express总线和多核优化的驱动程序和应用软件&#xff0c;提供了高性能功能…

「 LaTex 」写论文,Springer杂志插入ORCID

一、前言&#xff1a; 小白正在投Springer文章&#xff0c;遇“在作者右上角插入ORCID图标”问题&#xff0c;经挣扎后得此经验。成功后如下图&#xff1a; 二、技术实现 1. 插入库&#xff0c;代码如下&#xff1a; \usepackage{tikz,xcolor,hyperref} 2. 插入图标&#xff0…

Oracle错误——ORA-03113:通信通道的文件结尾 解决办法

由来 今天跟往常一样&#xff0c;登陆PL/SQL&#xff0c;确登陆失败&#xff0c;出现一个错误“ORA-01034”和“ORA-27101”如图&#xff1a; 然后就就通过命令提示符去登陆Oracle&#xff0c;去查看怎么回事&#xff0c;然后问题进一步出现&#xff0c;错误“ORA-03113:通信通…