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

    <!--开启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”

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

    • 优先查询二级缓存–>查询一级缓存–>数据库
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

水宝的滚动歌词

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值