1.缓存介绍
缓存是为了减小数据库的压力,且从缓存中查询数据,有助于提升查询效率。
mybatis的缓存分为一级缓存及二级缓存
**1.一级缓存:**默认是开启一级缓存的,一级缓存的作用域为sqlsession级别,sqlsession第一次查询时将数据结果缓存值一级缓存中(底层数据结构是Hashmap),第二次请求查询时,如果当前sqlsession未close或未commit,会从一级缓存中去查询数据。
如果发生增、删、改操作,将刷新一级缓存中的内容,下次查询时重新从数据库中读取,防止有脏数据。
2.二级缓存:默认是关闭状态,需要手动开启
<settings>
<setting "cacheEnabled"value="true"/>
</settings>
在mapper文件中增加如下标签方可开启二级缓存
<cache/>
二级缓存的作用域是namespace级别,namespace内所有的查询相关操作,都会统一缓存至当前namespace二级缓存下,或者说当前namespace下的sqlsession共享这个缓存,sqlsession关闭或commit时,下次重新获取sqlsession时,依然可以在二级缓存中去获取缓存数据。