了解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. 配置开启:二级缓存需要手动配置开启,需要在映射文件的标签下添加元素。

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

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

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

  6. 失效场景:

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

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

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

你可能感兴趣的:(mybatis,缓存)