Mybatis的缓存机制

Mybatis的缓存机制

MyBatis 提供了一级缓存和二级缓存两种缓存机制,以提高数据库查询的性能。

一级缓存(Local Cache)

  1. 作用范围:一级缓存是 SQL Session 级别的缓存,默认情况下是开启的。

  2. 实现原理:在同一个 SQL Session 中执行相同的查询时,MyBatis 会先在一级缓存中查找结果,如果找不到,再去数据库查询。查询结果会存储在 SQL Session 的缓存中。

    image-20240611193615676

  3. 失效场景

    • 执行了 insertupdatedelete 操作后,一级缓存会被清空。
    • 手动清空缓存:通过 sqlSession.clearCache() 方法清空一级缓存。
    • 不同的 SQL Session 之间的缓存不共享。

二级缓存(Global Cache)

  1. 作用范围:二级缓存是 Mapper 映射级别的缓存,多个 SQL Session 共享同一个 Mapper 的二级缓存。

  2. 实现原理:当一个 SQL Session 结束后,查询结果会存储到二级缓存中。下次执行相同的查询时,如果二级缓存中存在结果,则直接返回缓存结果,不再查询数据库。

    image (1)

  3. 配置方式

    • 在 MyBatis 配置文件中开启全局二级缓存:

      <settings>
        <setting name="cacheEnabled" value="true"/>
      </settings>
      
    • 在 Mapper 文件中配置二级缓存:

      <cache/>
      
    • 可以在 Mapper 文件中指定缓存的属性,例如清除策略、过期时间等:

      <cache eviction="LRU" flushInterval="60000" size="512" readOnly="true"/>
      
      • eviction:缓存回收策略,有 LRUFIFOSOFTWEAK
      • flushInterval:刷新间隔时间(毫秒)。
      • size:缓存大小。
      • readOnly:只读属性。
  4. 失效场景

    • 执行了 insertupdatedelete 操作后,对应的二级缓存会被清空。

    • 自定义缓存策略和清除规则。

      也不是不能用,读多写少的环境还是可以使用的。

使用注意事项

  • 一级缓存对于简单查询非常有效,但对于跨 SQL Session 的查询无效。
  • 二级缓存适用于频繁读取数据且数据更新频率较低的场景,但需要注意缓存过期和一致性问题。
  • 使用缓存时应谨慎考虑数据的一致性,特别是在多线程和分布式环境中。

通过合理配置和使用 MyBatis 的缓存机制,可以显著提升数据库查询的性能并减少数据库负载。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

曼诺尔雷迪亚兹

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

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

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

打赏作者

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

抵扣说明:

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

余额充值