程序员的公众号:源1024,获取更多资料,无加密无套路!
最近整理了一份大厂面试资料《史上最全大厂面试题》,Springboot、微服务、算法、数据结构、Zookeeper、Mybatis、Dubbo、linux、Kafka、Elasticsearch、数据库等等
获取方式: 关注公众号并回复 666 领取,更多内容持续奉上
MyBatis提供了两种级别的缓存:一级缓存(本地缓存)和二级缓存(全局缓存)
一级缓存(本地缓存):
-
作用范围:一级缓存是在SqlSession的生命周期内有效,也就是说,每个SqlSession拥有独立的一级缓存。
-
默认开启:一级缓存在MyBatis中默认是开启的。
-
特点:当执行查询操作时,查询的结果会被缓存在当前SqlSession中。如果再次执行相同的查询,MyBatis会首先尝试从缓存中获取数据,而不再访问数据库,提高了查询效率。
-
自动刷新:MyBatis会在执行insert、update、delete等操作时自动清空一级缓存,以保持数据的一致性。
-
失效场景:
使用不同的SqlSession对象导致无法看到一级缓存工作;
在一个SqlSession使用相同条件,但是,此时在查询之间进行数据修改操作会导致一级缓存失效。
二级缓存(全局缓存):
-
作用范围:二级缓存是在多个SqlSession之间共享的,即多个SqlSession可以共享同一个二级缓存。
-
配置开启:二级缓存需要手动配置开启,需要在映射文件的<mapper>标签下添加<cache>元素。
<cache eviction="FIFO" flushInterval="6000" readOnly="true" size="50"></cache>
-
特点:二级缓存能够跨SqlSession共享查询结果,有效减少数据库访问次数。它的数据存储在全局范围的缓存中,可以由多个SqlSession访问。
-
缓存策略:你可以根据需求选择不同的缓存策略(例如LRU、FIFO等),以及配置缓存的大小、刷新间隔等参数。
-
注意事项:二级缓存可以缓存的对象需要是可序列化的,要确保对象可以正确地序列化和反序列化。另外,对于关联数据的更新操作,需要手动清除相关的二级缓存,以避免脏数据的问题。
-
失效场景:
二级缓存进行增删改操作也会刷新二级缓存,导致二级缓存失效;
使用useCache 设置禁用二级缓存。在 statement 中设置 useCache=“false”,可以禁用当前 select 语句的二级缓存,即每次都会去数据库查询;
使用flushCache=“true” 属性刷新了缓存,一般执行完 commit 操作都需要刷新缓存,flushCache=“true” 表示刷新缓存,这样可以避免增删改操作而导致的脏读 。