一、一级缓存
1、一级缓存(本地缓存):
1)、一级缓存是基于sqlSession级别的缓存,在Mybatis中,一级缓存是一直开启的;
2)、一级缓存会创建一个sqlSession级别的一个Map,在与数据库同一次会话期间,将查询到的数据放在本地缓存中。
3)、在同一次会话期间,如果以后需要获取相同的数据,直接从缓存中拿,没必要再去查询数据库;
2、一级缓存失效情况:
1)、sqlSession不同,即不是同一次会话,每一次都会执行一遍Sql语句;
2)、sqlSession相同,查询条件不同;(当前一级缓存中还没有这个数据)
3)、sqlSession相同,两次查询之间执行了增删改操作;(在mysql中,每一次增删改操作都是清除一级缓存)
4)、sqlSession相同,手动清除了一级缓存(缓存清空),调用sqlSession.clearCache()方法;
二、二级缓存
二级缓存(全局缓存): 1、基于namespace级别的缓存,一个namespace对应一个二级缓存; 2、工作机制: (1)、一个会话,查询一条数据,这个数据就会被放在当前会话的一级缓存中; (2)、如果会话关闭,一级缓存中的数据会被保存到二级缓存中,新的会话查询信息,就可以参照二级缓存中的内容; (3)、不同namespace查出的数据会放在自己对应的缓存中(也就是各自的Map中)
sqlSession--->EmployeeMapper--->Employee
DepartmentMapper--->Department
(4)、效果:查出的数据都会被默认先放在一级缓存中,只有会话提交或者关闭以后,一级缓存中的数据才会转移到二级缓存中; (5)、使用:
1)、在Mybatis的配置文件中,开启全局二级缓存配置:
2)、去mapper.xml中配置使用二级缓存:
3)、此时的POJO需要实现序列化接口
(6)、和缓存有关的设置/属性:
1)、cacheEnabled=true:开启缓存
cacheEnabled=false:关闭缓存(二级缓存关闭)(一级缓存一直可用的)
2)、每个select标签都有useCache="true",如果设置为false,则表示不使用缓存,
每次执行查询操作,都会去查数据库,但一级缓存依然使用,二级缓存不会使用;
3)、每个增删改标签都会默认有:flushCache="true"属性,即每次执行增删改操作,
都会默认清空缓存,(一级二级都会清除)
4)、sqlSession.clearCache();只是清除当前sqlSession的一级缓存;
5)、localCacheScope:本地缓存作用域:(一级缓存SESSION);
当前会话的所有数据保存在会话缓存中;STATEMENT:可以禁用一级缓存;
三、整合第三方缓存
第三方缓存整合:
1)、导入第三方缓存包即可;
2)、导入与第三方缓存整合的适配包;
3)、在Mybatis设置文件中,设置开启缓存;
4)、在每个mapper.xml中的namespace标签下使用自定义缓存
参考Mybatis整合Ecache的官方文档,so easy~~~~ http://www.mybatis.org/ehcache-cache/