Mybatis的缓存机制
MyBatis 提供了一级缓存和二级缓存两种缓存机制,以提高数据库查询的性能。
一级缓存(Local Cache)
-
作用范围:一级缓存是 SQL Session 级别的缓存,默认情况下是开启的。
-
实现原理:在同一个 SQL Session 中执行相同的查询时,MyBatis 会先在一级缓存中查找结果,如果找不到,再去数据库查询。查询结果会存储在 SQL Session 的缓存中。
-
失效场景:
- 执行了
insert
、update
或delete
操作后,一级缓存会被清空。 - 手动清空缓存:通过
sqlSession.clearCache()
方法清空一级缓存。 - 不同的 SQL Session 之间的缓存不共享。
- 执行了
二级缓存(Global Cache)
-
作用范围:二级缓存是 Mapper 映射级别的缓存,多个 SQL Session 共享同一个 Mapper 的二级缓存。
-
实现原理:当一个 SQL Session 结束后,查询结果会存储到二级缓存中。下次执行相同的查询时,如果二级缓存中存在结果,则直接返回缓存结果,不再查询数据库。
-
配置方式:
-
在 MyBatis 配置文件中开启全局二级缓存:
<settings> <setting name="cacheEnabled" value="true"/> </settings>
-
在 Mapper 文件中配置二级缓存:
<cache/>
-
可以在 Mapper 文件中指定缓存的属性,例如清除策略、过期时间等:
<cache eviction="LRU" flushInterval="60000" size="512" readOnly="true"/>
eviction
:缓存回收策略,有LRU
、FIFO
、SOFT
、WEAK
。flushInterval
:刷新间隔时间(毫秒)。size
:缓存大小。readOnly
:只读属性。
-
-
失效场景:
-
执行了
insert
、update
或delete
操作后,对应的二级缓存会被清空。 -
自定义缓存策略和清除规则。
也不是不能用,读多写少的环境还是可以使用的。
-
使用注意事项
- 一级缓存对于简单查询非常有效,但对于跨 SQL Session 的查询无效。
- 二级缓存适用于频繁读取数据且数据更新频率较低的场景,但需要注意缓存过期和一致性问题。
- 使用缓存时应谨慎考虑数据的一致性,特别是在多线程和分布式环境中。
通过合理配置和使用 MyBatis 的缓存机制,可以显著提升数据库查询的性能并减少数据库负载。