MyBatis 的二级缓存是一种强大的查询缓存机制,它在默认情况下是关闭的。要启用二级缓存,需要在 SQL 映射文件中添加 <cache/>
标签。以下是对 MyBatis 二级缓存的详细解释:
1. 基本概念
-
一级缓存:基于 PerpetualCache 的 HashMap 本地缓存,其存储作用域为 Session。当 Session 冲刷(flush)或关闭(close)之后,该 Session 中的所有 Cache 将清空,默认打开一级缓存。
-
二级缓存:与一级缓存不同,其存储作用域为 Mapper(Namespace)。默认不开启二级缓存,但可以通过配置来启用,并且可以自定义存储源,如 Ehcache。
2. 启用和配置
要启用二级缓存,首先需要在 MyBatis 的全局配置文件中设置 cacheEnabled
参数为 True。然后,在 SQL 映射文件中添加 <cache/>
标签即可。
3. 缓存行为
- 缓存刷新:所有 insert、update 和 delete 操作都会刷新缓存。
- 缓存驱逐策略:使用 LRU(Least Recently Used)算法进行缓存对象的驱逐。此外,还可以设置其他驱逐策略,如 FIFO、SOFT 或 WEAK。
- 缓存大小:可以通过
size
属性设置缓存的最大引用数或对象数量。 - 刷新间隔:通过
flushInterval
属性设置以毫秒为单位的刷新间隔时间。 - 只读模式:通过
readOnly
属性设置为 true 或 false 来控制是否允许对缓存进行写操作。
4. 高级配置
除了上述基本配置外,还可以对缓存进行更高级的配置,例如实现自定义缓存或为第三方缓存方案创建适配器来完全覆盖缓存行为。
5. 示例代码
<configuration>
<settings>
<setting name="cacheEnabled" value="true"/>
</settings>
<mappers>
<mapper resource="path/to/your/mapper.xml "/>
</mappers>
</configuration>
<cache />
总结
MyBatis 的二级缓存提供了一种高效的数据访问优化手段,通过简单的配置即可实现强大的查询缓存功能。它不仅增强了应用的性能,还提高了数据处理的效率。通过灵活配置缓存参数,可以满足各种复杂场景下的需求。
标签:缓存,Session,配置,MyBatis,二级缓存,详解,mybatis,启用 From: https://blog.csdn.net/qq_64903447/article/details/140687772