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 的查询性能,尤其是在大量读操作的场景下。然而,缓存也增加了系统的复杂性,因此在设计和使用时需要权衡其利弊。

相关推荐
三两肉4 分钟前
Java 中 ArrayList、Vector、LinkedList 的核心区别与应用场景
java·开发语言·list·集合
clk66072 小时前
SSM 框架核心知识详解(Spring + SpringMVC + MyBatis)
java·spring·mybatis
Humbunklung2 小时前
Rust 控制流
开发语言·算法·rust
ghost1433 小时前
C#学习第27天:时间和日期的处理
开发语言·学习·c#
jason成都3 小时前
c#压缩与解压缩-SharpCompress
开发语言·c#
shangjg33 小时前
Kafka 的 ISR 机制深度解析:保障数据可靠性的核心防线
java·后端·kafka
傻啦嘿哟4 小时前
从零开始:用Tkinter打造你的第一个Python桌面应用
开发语言·c#
三十一6144 小时前
6.4 C++作业
开发语言·c++
我的golang之路果然有问题5 小时前
ElasticSearch+Gin+Gorm简单示例
大数据·开发语言·后端·elasticsearch·搜索引擎·golang·gin
Alan3165 小时前
Qt 中,设置事件过滤器(Event Filter)的方式
java·开发语言·数据库