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

相关推荐
Boilermaker1992几秒前
【Java EE】SpringIoC
前端·数据库·spring
wjs20241 分钟前
SOAP Header 元素
开发语言
Super Rookie1 分钟前
Spring Boot 企业项目技术选型
java·spring boot·后端
写不出来就跑路7 分钟前
Spring Security架构与实战全解析
java·spring·架构
无限远的弧光灯21 分钟前
c语言学习_函数递归
c语言·开发语言·学习
趣多多代言人28 分钟前
从零开始手写嵌入式实时操作系统
开发语言·arm开发·单片机·嵌入式硬件·面试·职场和发展·嵌入式
胖大和尚38 分钟前
C++项目学习计划
开发语言·c++·学习
开开心心_Every40 分钟前
全能视频处理工具介绍说明
开发语言·人工智能·django·pdf·flask·c#·音视频
ZeroNews内网穿透43 分钟前
服装零售企业跨区域运营难题破解方案
java·大数据·运维·服务器·数据库·tcp/ip·零售
sleepcattt1 小时前
Spring中Bean的实例化(xml)
xml·java·spring