当前位置: 首页 > article >正文

35. MyBatis中的缓存失效机制是如何工作的?

MyBatis 提供了两级缓存机制:一级缓存和二级缓存。缓存失效机制在 MyBatis 中起着至关重要的作用,以确保数据的正确性和一致性。下面我们来详细了解 MyBatis 中一级缓存和二级缓存的失效机制。

1. 一级缓存失效机制

一级缓存是 MyBatis 默认开启的缓存机制,作用范围是 SqlSession 级别。一级缓存的生命周期与 SqlSession 相同。它的失效机制如下:

1.1 一级缓存的默认行为

  • 默认缓存:在同一个 SqlSession 实例中,如果执行了相同的查询(相同的 SQL 语句和参数),MyBatis 会从一级缓存中获取结果,而不是重新访问数据库。

1.2 一级缓存的失效条件

以下几种情况会导致一级缓存失效:

  1. 执行了 INSERTUPDATEDELETE 操作:

    • 当在 SqlSession 中执行了增、删、改操作时,MyBatis 会清空一级缓存。这是为了确保数据一致性,因为增、删、改操作可能改变数据库中的数据,因此之前缓存的查询结果可能已经过时。

  2. 手动清空缓存:

    • 可以通过调用 SqlSession.clearCache() 方法手动清空一级缓存。这通常用于在特殊情况下主动刷新缓存。

  3. SqlSession 关闭:

    • SqlSession 关闭时,一级缓存随之被销毁。不同的 SqlSession 实例拥有各自独立的缓存。

  4. 执行不同的查询:

    • 如果在 SqlSession 中执行了不同的查询(不同的 SQL 语句),MyBatis 不会使用之前缓存的结果。

2. 二级缓存失效机制

二级缓存是 MyBatis 提供的全局缓存机制,作用范围是 Mapper 映射器级别。二级缓存默认是关闭的,必须显式开启。二级缓存的失效机制如下:

2.1 二级缓存的默认行为

  • 缓存共享:二级缓存是跨 SqlSession 的,同一个 Mapper 映射器下的多个 SqlSession 实例可以共享缓存的数据。

  • 配置缓存:二级缓存需要在 MyBatis 配置文件或 Mapper 文件中进行配置。可以通过 <cache> 标签启用二级缓存,并设置缓存策略、刷新间隔等。

2.2 二级缓存的失效条件

二级缓存的失效机制主要包括以下几种情况:

  1. 执行了 INSERTUPDATEDELETE 操作

    • 与一级缓存类似,当 Mapper 执行了增、删、改操作时,对应的二级缓存会被清空或标记为无效。这是为了确保其他 SqlSession 实例能够获取最新的数据库数据。

  2. 配置了缓存刷新间隔

    • 可以在 <cache> 标签中配置 flushInterval 属性,指定缓存的刷新间隔时间。超过指定时间后,缓存将自动失效。

    <cache flushInterval="60000" /> <!-- 缓存 60 秒后自动失效 -->
  3. 手动清空缓存

    • 可以通过 SqlSession.clearCache() 方法手动清空当前 SqlSession 所关联的二级缓存。

  4. 配置缓存大小

    • 可以通过 <cache> 标签中的 size 属性配置缓存的最大对象数目。当缓存达到指定大小时,旧的缓存数据将被清除,以腾出空间存储新的数据。

    <cache size="512" /> <!-- 缓存最多保存 512 个对象 -->
  5. 配置缓存策略

    • 可以通过 eviction 属性配置缓存的回收策略,如 LRU(最近最少使用)、FIFO(先进先出)、SOFT(软引用)、WEAK(弱引用)。当缓存满时,根据策略清理旧数据。

    <cache eviction="LRU" /> <!-- 使用 LRU 策略 -->

  6. 使用 readOnly 属性

    • 配置 readOnly 属性为 true 时,缓存的数据将被标记为只读。在这种情况下,返回的对象会被共享,无法修改。

    <cache readOnly="true" /> <!-- 缓存数据为只读,提升性能 -->

3. 总结

  • 一级缓存失效机制:一级缓存作用于 SqlSession 级别,默认开启。当执行增删改操作、手动清空缓存、SqlSession 关闭或执行不同查询时,一级缓存将失效。

  • 二级缓存失效机制:二级缓存作用于 Mapper 映射器级别,默认关闭。可以通过配置启用二级缓存,并设置失效条件,如增删改操作、手动清空、刷新间隔、缓存策略等。

MyBatis 的缓存失效机制确保了数据的正确性和一致性,在适当的场景下使用缓存可以显著提升应用程序的性能,但同时也要注意缓存的失效条件,以避免因缓存数据不一致而导致的问题。


http://www.kler.cn/news/312280.html

相关文章:

  • pytorch入门(1)——pytorch加载数据初认识
  • Nginx:高性能Web服务器与反向代理的深度剖析
  • 契约锁与您相约2024新疆数字经济创新大会暨新疆数字丝路博览会
  • QT支持C/C++工业边缘计算网关带RS485、HDMI视频输出
  • pinia在vue3中的使用
  • 分布式训练:(Pytorch)
  • AI免费UI页面生成
  • Vue 67 vuex 四个map方法的使用
  • Azure OpenAI and token limit
  • 可转债量化策略研究,QMT如何获取可转债合约信息?
  • 【Day03-MySQL单表】
  • ubuntu下使用qt编译QOCI(libqsqloci.so)驱动详解及测试
  • linux-软件包管理-包管理工具(RedHat/CentOS 系)
  • Vue.js 的 Mixins
  • 2024.9.20 Python模式识别新国大EE5907,PCA主成分分析,LDA线性判别分析,GMM聚类分类,SVM支持向量机
  • vue中动态引入加载图片不显示
  • 【网络安全 | 代码审计】JFinal之DenyAccessJsp绕过
  • 算法.图论-建图/拓扑排序及其拓展
  • 未来展望:等保测评技术的发展趋势与创新方向
  • 多路转接之epoll的两种触发方式(LT,ET的效率对比,原理,epoll读取数据的过程)
  • 算法基础-二分查找
  • 2025秋招LLM大模型多模态面试题(六)-KV缓存
  • 亿级数据表多线程update锁表问题
  • 浅谈人工智能之基于ollama本地大模型结合本地知识库搭建智能客服
  • 2024最新版,人大赵鑫老师《大语言模型》新书pdf分享
  • 嵌套函数的例子(TypeScript)
  • QT QObject源码学习(二)
  • Netty源码解析-请求处理与多路复用
  • uniapp中使用picker-view选择时间
  • vulhub搭建漏洞环境docker-compose up -d命令执行报错以及解决方法汇总