简介
一级缓存:线程级别的缓存,本地缓存,是sqlSession级别的缓存,默认开启
二级缓存:全局范围的缓存,其他sqlSession也能使用,是namespace级别的缓存,手动开启
工作流程
当我们一个查询语句过来时,先走去二级缓存中看有没有这个缓存,如果没有命中,才会去一级缓存中拿取缓存,如果一级缓存中也没有命中,那么我们这时候才会直接走数据库,当我们走数据库查询到了这条记录,然后我们会将这条记录缓存到一级缓存中,当我们一级缓存关闭时,才会将一级缓存中的数据缓存到二级缓存中。
缓存相关设置
useCache:是否使用二级缓存
flushCache:清空缓存(同时清空一级缓存和二级缓存),查询默认是false
sqlSession.clearCache():清空一级缓存
当在某一个作用域中进行了C/U/D操作,默认该作用下的所有select的缓存将会被clear
二级缓存通过<setting name="cacheEnabled" value="true"/>手动开启