mybatis缓存

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

    
    
    <cache eviction="LRU" flushInterval="100000" size="1024" readOnly="true"/>
    
    <settings>
        
        <setting name="cacheEnabled" value="true"/>
    settings>
    
  • 如果需要控制全局mapper里面某个方法不使用缓存,可以配置useCache=“false”

  • 一级缓存和二级缓存使用顺序

    • 优先查询二级缓存–>查询一级缓存–>数据库

你可能感兴趣的:(mybatis,mybatis)