了解MyBatis的缓存机制吗


程序员的公众号:源1024,获取更多资料,无加密无套路!

最近整理了一份大厂面试资料《史上最全大厂面试题》,Springboot、微服务、算法、数据结构、Zookeeper、Mybatis、Dubbo、linux、Kafka、Elasticsearch、数据库等等
获取方式: 关注公众号并回复 666 领取,更多内容持续奉上

MyBatis提供了两种级别的缓存:一级缓存(本地缓存)和二级缓存(全局缓存)

一级缓存(本地缓存)

  1. 作用范围:一级缓存是在SqlSession的生命周期内有效,也就是说,每个SqlSession拥有独立的一级缓存。

  2. 默认开启:一级缓存在MyBatis中默认是开启的。

  3. 特点:当执行查询操作时,查询的结果会被缓存在当前SqlSession中。如果再次执行相同的查询,MyBatis会首先尝试从缓存中获取数据,而不再访问数据库,提高了查询效率。

  4. 自动刷新:MyBatis会在执行insert、update、delete等操作时自动清空一级缓存,以保持数据的一致性。

  5. 失效场景:

    使用不同的SqlSession对象导致无法看到一级缓存工作;

    在一个SqlSession使用相同条件,但是,此时在查询之间进行数据修改操作会导致一级缓存失效。

二级缓存(全局缓存)

  1. 作用范围:二级缓存是在多个SqlSession之间共享的,即多个SqlSession可以共享同一个二级缓存。

  2. 配置开启:二级缓存需要手动配置开启,需要在映射文件的<mapper>标签下添加<cache>元素。

    <cache eviction="FIFO" flushInterval="6000" readOnly="true" size="50"></cache>

  3. 特点:二级缓存能够跨SqlSession共享查询结果,有效减少数据库访问次数。它的数据存储在全局范围的缓存中,可以由多个SqlSession访问。

  4. 缓存策略:你可以根据需求选择不同的缓存策略(例如LRU、FIFO等),以及配置缓存的大小、刷新间隔等参数。

  5. 注意事项:二级缓存可以缓存的对象需要是可序列化的,要确保对象可以正确地序列化和反序列化。另外,对于关联数据的更新操作,需要手动清除相关的二级缓存,以避免脏数据的问题。

  6. 失效场景:

    二级缓存进行增删改操作也会刷新二级缓存,导致二级缓存失效;

    使用useCache 设置禁用二级缓存。在 statement 中设置 useCache=“false”,可以禁用当前 select 语句的二级缓存,即每次都会去数据库查询;

    使用flushCache=“true” 属性刷新了缓存,一般执行完 commit 操作都需要刷新缓存,flushCache=“true” 表示刷新缓存,这样可以避免增删改操作而导致的脏读 。

  • 8
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值