MyBatis的缓存会将select语句的查询结果放到缓存(内存)当中,下一次还是这条select语句的话,直接从缓存中取,不再查数据库。一方面是减少了IO。另一方面不再执行繁琐的查找算法。效率大大提升。
mybatis缓存包括:
缓存只针对于DQL语句,也就是说缓存机制只对应select语句。
一级缓存默认是开启的,不需要做任何配置。
原理:只要使用同一个SqlSession对象执行同一条SQL语句,就会走缓存。
什么情况下不走缓存?
第一种:第一次查询和第二次查询之间,手动清空了一级缓存。
sqlSession.clearCache();
第二种:第一次查询和第二次查询之间,执行了增删改操作。(这个增删改和哪张表没有关系,只要有insert delete update操作,一级缓存就失效。)
二级缓存的范围是SqlSessionFactory。
使用二级缓存需要具备以下几个条件:
二级缓存的失效:只要两次查询之间出现了增删改操作。二级缓存就会失效。【一级缓存也会失效】
二级缓存的相关配置:
1、eviction:指定从缓存中移除某个对象的淘汰算法。默认采用LRU策略。
LRU:Least Recently Used。最近最少使用。优先淘汰在间隔时间内使用频率最低的对象。(还有一种淘汰算法LFU,最不常用)。
FIFO:First In First Out。一种先进先出的数据缓存器。先进入二级缓存的对象最先被淘汰。
SOFT:软引用。淘汰软引用指向的对象。具体算法和JVM的垃圾回收算法有关。
WEAK:弱引用。淘汰弱引用指向的对象。具体算法和JVM的垃圾回收算法有关。
2、flushInterval:二级缓存的刷新时间间隔。单位毫秒。如果没有设置。就代表不刷新缓存,只要内存足够大,一直会向二级缓存中缓存数据。除非执行了增删改。
3、readOnly:
false:多条相同的sql语句执行之后返回的对象是副本,调用了clone方法。性能一般。但安全
4、size:设置二级缓存中最多可存储的java对象数量。默认值1024。