Mybatis二级缓存
简介:二级缓存是namespace级别的,多个SqlSession去操作同一个namespace下的
Mapper的sql语句,多个SqlSession可以共用二级缓存,如果两个mapper的namespace相
同,(即使是两个mapper,那么这两个mapper中执行sql查询到的数据也将存在相同的二级
缓存区域中,但是最好是每个Mapper有单独的名称空间)
基于PerpetualCache 的 HashMap本地缓存,可自定义存储源,如 Ehcache/Redis等
默认是没有开启二级缓存
操作流程:第一次调用某个namespace下的SQL去查询信息,查询到的信息会存放该
mapper对应的二级缓存区域。 第二次调用同个namespace下的mapper映射文件中,相同
的sql去查询信息,会去对应的二级缓存内取结果
失效策略:执⾏同个namespace下的mapepr映射文件中增删改sql,并执行了commit操作,会清
空该二级缓存
注意:实现二级缓存的时候,MyBatis建议返回的POJO是可序列化的, 也就是建议实现
Serializable接口
缓存淘汰策略:会使用默认的 LRU 算法来收回(最近最少使用的)
开启方法:
1.在mybatis-config.xml添加:
<setting name="cacheEnabled" value="true"/>
2.在Mapper.xml中添加:
<cache eviction="LRU" flushInterval="10000" size="1024" readOnly="true"/>
3.某个方法不行用缓存,关闭方法:(useCache=“false”)
效果截图:
开启二级缓存前:
开启二级缓存后:
关闭某些方法的二级缓存后: