1、在MyBatis中,缓存可以通过两种方式进行开启:一级缓存和二级缓存。
2、一级缓存:默认情况下,MyBatis开启了一级缓存。它是SqlSession内部的一个缓存。当多次执行同样的查询语句时,第一次查询时会将结果放入一级缓存中,在第二次查询相同的语句时,直接从缓存中获取,避免了重复的 SQL 执行,提高了性能。
3、二级缓存:与一级缓存不同的是,二级缓存是需要手动开启的,并且它是跨 SqlSession 的缓存。如果多个 SqlSession 执行相同的查询语句,那么这些查询结果会被放到同一个二级缓存中。在 MyBatis 中,可以使用 cache 标签开启二级缓存。同时还需配置对应缓存提供者实现类,比如 Ehcache、Redis 等。
开启步骤:
1).在 mybatis-config.xml 的配置文件中进行显示配置,开启二级缓存(全局缓存)
2).在 Mapper.xml 文件中添加cache标签
i、开启全局缓存
在Mybatis的官方文档中可以看出已经默认开启了二级缓存
但为了代码的可读性,在团队开发中为了方便的告诉队员你使用了二级缓存,这时候需要在 mybatis-config.xml 的配置文件中手动添加开启设置。二级缓存是基于namespace级别的,一个命名空间对应一个二级缓存。
<settings>
<!--显示的开启全局缓存-->
<setting name="cacheEnabled" value="true"/>
</settings>
ii、在 Mapper.xml 文件中添加cache标签
在要使用二级缓存的Mapper.xml文件中添加cache标签
<!--在当前 Mapper.xml文件开启二级缓存-->
<cache/>
也可以自定义cache标签参数
<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>
eviction:清除策略为FIFO缓存,先进先出原则,默认的清除策略是 LRU
flushInterval:属性可以被设置为任意的正整数,设置的值应该是一个以毫秒为单位的合理时间量
size:最多可以存储结果对象或列表的引用数
readOnly:只读属性,可以被设置为 true 或 false。
iii、注意点
我们在使用缓存的时候要记得序列化实体类,否则会抛出实体类未序列化异常
需要在实体类添加 implements Serializable
iiii总结
- 二级缓存是基于namespace级别的,在同一个Mapper下有效
- 所有的数据都会先放在一级缓存中
- 只有当会话提交或关闭时,才会提交到二级缓存中
4、需要注意的是,缓存虽然可以提高系统性能,但有时也会因为缓存数据过时或者数据不一致等问题,造成脏数据问题。在开启缓存时,要根据具体情况适当调整缓存策略,以确保数据的一致性和正确性。
版权声明:本文为CSDN博主「你干嘛诶哟~」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/m0_69602951/article/details/131080053