mybatis提供缓存支持,默认情况下只会开启一级缓存。
一级缓存
一级缓存失效情况
SqlSession不同;
SqlSession相同,但查询条件不同;
SqlSession相同,但两次查询之间执行了任何一次增删改操作;
SqlSession相同,但使用clearCache()方法手动清除了一级缓存
除此之外,一级缓存均会开启。
二级缓存
如何开启二级缓存,在mybatie-config.xml
<settings>
<!--开启二级缓存-->
<setting name="cacheEnabled" value="true"/>
</settings>
除此之外还需在sql有映射文件制定cache标签
<cache eviction="FIFO" flushInterval="60000" readOnly="false" size="1024"/>
注意:对应的POJO需要实现Serializable接口。
缓存总结
/**
* 与缓存有关的设置/属性:
* 1). 默认cacheEnabled=true,若为false则关闭二级缓存,而一级缓存一直可用的
* 2). 每个select标签都有useCache="true"属性
* 若为false则不使用缓存(一级缓存依然使用,二级缓存不使用)
* 3). 每个增删改标签都有flushCache="true"属性,即两级缓存都会清除
* 增删改执行完成后即会自动清除缓存;
* 查询标签的flushCache="false",若其为true则每次查询后都会清空缓存。
* 4). sqlSession.clearCache()方法只是清除当前session的一级缓存
* 5). localCacheScope属性为本地缓存作用域,一级缓存取值SESSION,取值STATEMENT即可禁用一级缓存
*/