前提提要
mybatis默认定义了两种缓存:一级缓存和二级缓存.
1.默认情况下,只有一级缓存(sqlsession级别的缓存,也称为本地缓存)
与数据库的一次会话期间,如果取到相同的数据,就会从缓存中拿.
一级缓存一直开启.
2.二级缓存(全局缓存)需要手动开启和配置,他是基于namespace级别的缓存,一个namespace对应一个缓存.
3.为了提高扩展性,Mybatis定义了缓存的接口Cache.我们可以通过实现Cache来自定义二级缓存
4.工作原理:
(1)一个会话查询一条数据,这个数据就会被放在当前会话的一级缓存中
(2)如果这个会话关闭,一级缓存中的数据会被保存到二级缓存中;新的会话查询信息的话,就可以参照二级缓存了
一级缓存失效的情况
1.sqlsession不同
2.sqlsession相同,查询条件不同
3.sqlsession相同,两次查询中间进行过增删改操作
4.sqlsession相同,但手动清空了一级缓存.sqlsession.clearCache()
二级缓存的使用
1.在全局配置文件中开启二级缓存
<settings>
<!--只影响二级缓存,一级缓存不受影响-->
<setting name="cacheEnabled" value