1.一级缓存(默认开启)
Mybatis对缓存提供支持,但是在没有配置的默认情况下,它只开启一级缓存。
一级缓存只是相对于同一个SqlSession而言。所以在参数和SQL完全一样的情况下,我们使用同一个SqlSession对象调用一个Mapper方法,只执行一次SQL,使用SelSession第一次查询后,MyBatis会将其放在缓存中,以后再查询的时候,如果之前没有执行commit操作,并且缓存没有超时的情况下,SqlSession都会取出当前缓存的数据,而不会再次发送SQL到数据库。每次sqlSession去执行commit操作(插入,更新,删除)会自动清除sqlSession中的一级缓存,session关闭后,该sqlSession中一级缓存中的内容将自动清除,避免脏读。
不同的sqlSession之间的缓存区域(HashMap)互不影响。
2.二级缓存(手动开启)
mybaits的二级缓存是mapper范围级别,除了在SqlMapConfig.xml设置二级缓存的总开关,还要在具体的mapper.xml中开启二级缓存。
<setting name="cacheEnabled" value="true" />
开启全局配置
在mapper.xml配置文件开启缓存:<cache/>
pojo需要实现序列化接口。
sqlSession需要关闭后才能将数据写到二级缓存中,否则二级缓存中无相应数据。
任何一个sqlsession执行提交操作都会清空二级缓存中的内容。
在statement中设置useCache=false可以禁用当前select语句的二级缓存,即每次查询都会发出sql去查询
使用场景:
- 用于查询非常消耗时间的查询请求
- 用于访问次数多的查询请求且用户对查询结果实时性要求不高