MyBatis的一级、二级缓存

MyBatis 提供了两级缓存机制,即一级缓存和二级缓存,用于提高查询效率,减少数据库访问次数。

一级缓存(Session Cache)

一级缓存是 MyBatis 的默认缓存,它是基于 SQL Session 的缓存。在同一个 SQL Session 中,执行相同的查询语句,MyBatis 会将第一次查询结果缓存起来,后续的查询将直接从缓存中获取数据,而不会再次执行数据库查询。

一级缓存的工作原理
缓存作用域:一级缓存的作用域是同一个 SQL Session。这意味着一旦 SQL Session 关闭,缓存就会被清空。
缓存存储:一级缓存的数据存储在 PerpetualCache 类的一个 HashMap 中,它是基于内存的。
缓存命中:当执行查询时,MyBatis 会先检查一级缓存中是否有相同查询的结果。如果有,则直接返回缓存数据;如果没有,则执行数据库查询,并将结果存入缓存。
缓存失效:任何更新操作(INSERT、UPDATE、DELETE)都会导致一级缓存被清空,因为数据可能已发生变化。

一级缓存的配置
++一级缓存默认是开启的,不需要额外配置。++ 但是,可以通过以下方式来控制它。

在 MyBatis 配置文件中设置 <settings> 元素的 localCacheScope 属性,可以设置为 SESSION(默认)或 STATEMENT。如果设置为 STATEMENT,则每次执行完一个 SQL 语句后,缓存就会被清空。

二级缓存(Global Cache)

二级缓存是跨多个 SQL Session 的缓存,它的工作原理类似于一级缓存,但是其作用域是全局的,可以被多个 SQL Session 共享。
二级缓存的工作原理
缓存作用域:二级缓存的作用域是同一个 namespace,即同一个 Mapper 映射文件。
缓存存储:二级缓存默认使用 PerpetualCache,但可以通过实现 Cache 接口来使用不同的缓存实现,如 Ehcache、Redis 等。

缓存命中:当执行查询时,MyBatis 会先检查一级缓存,如果未命中,再检查二级缓存。如果二级缓存中有数据,则直接返回;如果没有,则执行数据库查询,并将结果存入二级缓存。
缓存失效:与一级缓存类似,任何更新操作都会导致二级缓存失效。

二级缓存的配置

++要启用二级缓存,需要进行以下配置++ :

在 MyBatis 配置文件中设置 <settings> 元素的 cacheEnabled 属性为 true(默认为 true)。

在需要使用二级缓存的 Mapper 映射文件中添加 <cache> 元素。

在需要被缓存的查询语句上添加 useCache="true" 属性。

对于需要缓存的对象,该对象类必须实现 java.io.Serializable 接口,以便能够序列化到缓存中。
注意事项

二级缓存的数据在不同 SQL Session 之间共享,因此需要谨慎处理并发问题。

在分布式环境下,使用二级缓存可能会遇到数据一致性问题。

通过合理使用一级和二级缓存,可以显著提高 MyBatis 的查询性能,尤其是在大量读操作的场景下。然而,缓存也增加了系统的复杂性,因此在设计和使用时需要权衡其利弊。

相关推荐
3GPP仿真实验室13 分钟前
【Matlab源码】6G候选波形:OFDM-IM 增强仿真平台 DM、CI
开发语言·matlab·ci/cd
devmoon16 分钟前
在 Polkadot 上部署独立区块链Paseo 测试网实战部署指南
开发语言·安全·区块链·polkadot·erc-20·测试网·独立链
lili-felicity17 分钟前
CANN流水线并行推理与资源调度优化
开发语言·人工智能
爬山算法17 分钟前
Hibernate(87)如何在安全测试中使用Hibernate?
java·后端·hibernate
沐知全栈开发17 分钟前
CSS3 边框:全面解析与实战技巧
开发语言
island131427 分钟前
CANN GE(图引擎)深度解析:计算图优化管线、内存静态规划与异构 Stream 调度机制
c语言·开发语言·神经网络
云姜.30 分钟前
线程和进程的关系
java·linux·jvm
是码龙不是码农31 分钟前
支付防重复下单|5 种幂等性设计方案(从初级到架构级)
java·架构·幂等性
曹牧32 分钟前
Spring Boot:如何在Java Controller中处理POST请求?
java·开发语言
heartbeat..32 分钟前
JVM 性能调优流程实战:从开发规范到生产应急排查
java·运维·jvm·性能优化·设计规范