mybatis一级缓存
- 什么是缓存
- 程序经常要调用的对象存在内存中,方便其使用时可以快速调用,不必去数据库或者其他持久化设备中查询,主要就是提高性能
- mybatis一级缓存
- 简介:一级缓存的作用域是SqlSession,同一个SqlSession中执行相同的SQL查询(相同的SQL和参数),第一次会去查询数据库并写在缓存中,第二次会直接从缓存中取
- 基于PerpetualCache的HashMap本地缓存
- 默认开启一级缓存
- 失效策略:当执行SQL时候两次查询中间发生了增删改的操作,即insert、delete、update等操作,commit后会清空该SqlSession缓存;比如SqlSession关闭或者清空等
mybatis二级缓存
-
mybatis二级缓存
- 简介:二级缓存是namespace级别的,多个SqlSession去操作同一个namespace下的mapper的SQL语句,多个SqlSession可以共用二级缓存,如果两个mapper的namespace相同(即使是两个mapper,那么这两个mapper中执行SQL查询到的数据也将存在相同的二级缓存区域中,但是最好是每个mapper单独的名称空间)
- 基于PerpetualCache的HashMap本地缓存,可自定义存储源,如Ehcache/redis等
- 默认没有开启二级缓存
- 操作流程:第一次调用某个namespace下的SQL去查询信息,查询到的信息会存放该mapper对应的二级缓存区域。第二次调用同个namespace下的mapper映射文件中,相同的SQL去查询信息,会去对应的二级缓存内取结果
-
失效策略:执行同个namespace下的mapper映射文件中增删改SQL,并执行了commit操作会清空该二级缓存
-
注意:实现二级缓存的时候,mybatis建议返回的POJO是可序列化的,也就是建议实现Serializable接口
-
缓存淘汰策略:会使用默认的LRU算法来回收(最近最少使用的)
-
如何开启某个二级缓存mapper.xml里面配置,测试时注意SqlSession需要commit或者close
<!--开启mapper的namespace下的二级缓存--> <!-- eviction:缓存回收策略,常见下面两种 1)LRU:最近最少使用的,移除最长时间不用的对象 2)FIFO:先进先出,按对象进入缓存的顺序来移除他们 flushInterval:刷新间隔时间,单位毫秒。这里配置100秒刷新,如果不配置,当SQL被执行的时候才会去刷新缓存 size:引用数目,代表缓存最多可以存储多少个对象,设置过大会导致内存溢出 readOnly:只读,缓存数据只能读取而不能修改,默认值是false --> <cache eviction="LRU" flushInterval="100000" size="1024" readOnly="true"/>
<settings> <!--全局配置:二级缓存总开关--> <setting name="cacheEnabled" value="true"/> </settings>
-
如果需要控制全局mapper里面某个方法不使用缓存,可以配置useCache=“false”
-
一级缓存和二级缓存使用顺序
- 优先查询二级缓存–>查询一级缓存–>数据库