Mybatis缓存之二级缓存详解

Mybatis二级缓存

  • 二级缓存也叫全局缓存,一级缓存作用域太低了,所以诞生了二级缓存

  • 基于namespace级别的缓存,一个名称空间,对应一个二级缓存;

  • 工作机制

    • 一个会话查询一条数据,这个数据就会被放在当前会话的一级缓存中;
    • 如果当前会话关闭了,这个会话对应的一级缓存就没了;但是我们想要的是,会话关闭了,一级缓存中的数据被保存到二级缓存中
    • 新的会话查询信息,就可以从二级缓存中获取内容;
    • 不同的mapper查出的数据会放在自己对应的缓存(map)中;

二级缓存的使用步骤

  1. 开启全局缓存 【mybatis-config.xml】
 <setting name="cacheEnabled" value="true"/>

Mybatis缓存之二级缓存详解

  1. 去每个mapper.xml中配置使用二级缓存,这个配置非常简单;【xxxMapper.xml】
    <cache />
    <cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>
  1. 测试
    注意:我们需要将实体类序列化 否则会报错
    Mybatis缓存之二级缓存详解
    解决方案
    Mybatis缓存之二级缓存详解
    小结:
  • 只要开启了二级缓存,在同一个Mapper下就有效
  • 所有的数据都会先放在一级缓存中
  • 只有当会话提交,或者关闭的时候,才会提交到二级缓存中

缓存原理

Mybatis缓存之二级缓存详解
首先有一个数据库,查询数据库 它需要有多个SqlSession,查出的一瞬间,结果被缓存到SqlSession(一级缓存)

存在多个SqlSession的时候,第一次查询走数据库,第二次查询走缓存。

缓存顺序:

  1. 第一次查询先看二级缓存中有没有
  2. 再看一级缓存中有没有
  3. 两个都没有再查询数据库

如果对您有帮助,免费的赞点一个 感谢

上一篇:【Mybatis源码解析】MyBatis执行Sql的流程分析


下一篇:一级缓存