Mybatis 一级缓存,二级缓存
在开发过程中偶尔遇到在修改数据库数据之后,程序代码依然查到的是修改前的数据,这可能是由于myBatis缓存的导致第二次查询读取的是缓存里的数据。
1.一级缓存
MyBatis 默认开启了一级缓存,一级缓存是sqlSession级别的缓存,在执行相同的sql时,若sql未发生改变,会从缓存中直接取出上次的查询数据并返回。
- 一级缓存的声明周期:
1.MyBatis在开启一个数据库会话时,会创建一个新的SqlSession对象,SqlSession对象会有一个新的Executor对象。Executor对象中持有一个新的PerPetualCache对象;当会话结束时,SqlSession对象内部的Executor对象还有PerPetualCache对象也一并被释放掉。
2.如果SqlSession调用了close()方法,会释放掉一级缓存PerpetualCache对象,一级缓存将不可用。
3.如果SqlSession调用了clearCache(),会清空PerpetualCache对象中的数据,但是该对象仍可使用。
4.qlSession中执行了任何一个update操作(update()、delete()、insert()) ,都会清空PerpetualCache对象的数据,但是该对象可以继续使用。
5.SqlSession中调用commit和rollback方法,这个相当于是我们开发中涉及的事物调用的方法,所以事物的提交和回滚也会清空PerpetualCache对象中的数据 - PerpetualCache储存器。一级缓存是通过PerpetualCache类操作的,其实就是内存缓存,通过map保存在内存中。
- 不同的SqlSession是相互隔离的,若是通过不同的SqlSession容器查询还是会去重新查询。
2.二级缓存
二级缓存克服了一级缓存的问题,在SqlSessionFactory层面实现了SqlSession的共享。、
MyBatis默认二级缓存不开启的,而在springBoot中集成的MyBatis是默认开启的,使用时需要声明使用注释@CacheNamespace声明
-
Cache过期策略:
-
LRU:最少使用原则,移除最长时间不使用的对象
-
FIFO:先进先出原则,按照对象进入缓存顺序进行回收
-
SOFT:软引用,移除基于垃圾回收器状态和软引用规则的对象
-
WEAK:弱引用,更积极的移除移除基于垃圾回收器状态和弱引用规则的对象
-
二级缓存的应用场景:
1.对于访问多的,实用性要求不高的查询请求,可以采取二级缓存。
2.对于查询特别耗时的请求,且实时性不高的请求 -
二级缓存局限性:
细粒度缓存就是,针对某个商品,如果要修改其信息,只修改该商品的缓存数据,缓存区的其他数据不动(不会因为某个商品信息的修改就直接清空整个缓存区)