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

【Java 开发日记】我们来说一下 Mybatis 的缓存机制

【Java 开发日记】我们来说一下 MyBatis 的缓存机制

MyBatis 的缓存机制是其性能优化的重要组成部分,也是面试中非常高频的考察点。
很多人只知道“一级缓存、二级缓存”,但真正理解它们的生命周期、使用场景、失效时机、线程安全问题以及实际项目中的正确用法的人并不多。

今天我们系统地把 MyBatis 缓存机制讲透。

一、MyBatis 缓存分类总览

缓存层级范围默认开启存储介质线程安全命中时机失效时机
一级缓存SqlSession 级别开启内存(HashMap)同一个 SqlSession 内相同查询SqlSession 关闭 / commit / rollback / update 等
二级缓存Mapper 级别关闭内存 / Ehcache / Redis 等是(需配置)跨 SqlSession 的相同查询缓存时间到 / update 操作 / flushCache=true
查询缓存单个查询语句级别通过 useCache / flushCache 属性控制

二、一级缓存(Session 级缓存)详解

核心特点

  • 作用域:同一个 SqlSession 生命周期内
  • 默认开启,无法通过配置关闭(只能通过清空的方式绕过)
  • 存储结构PerpetualCache(本质是一个 HashMap)
  • 缓存 Key:由 SQL + 参数 + 环境 + 数据库 + 映射语句 ID 等组成

什么时候命中一级缓存

SqlSessionsession=sqlSessionFactory.openSession();Useru1=session.selectOne("com.xxx.mapper.UserMapper.getUser",1);Useru2=session.selectOne("com.xxx.mapper.UserMapper.getUser",1);System.out.println(u1==u2);// true!命中一级缓存,返回同一个对象

一级缓存失效的 6 大场景(非常高频考点):

  1. SqlSession 关闭(最常见)
  2. SqlSession 调用 commit() 或 rollback()
  3. 执行了任意增删改操作(即使是其他 Mapper 的 update)
  4. 手动调用session.clearCache()
  5. 使用了flushCache=true的查询语句
  6. 不同 SqlSession 之间天然不共享

代码验证一级缓存失效

Useru1=mapper.getUser(1);// 查数据库Useru2=mapper.getUser(1);// 一级缓存命中session.commit();// commit 后一级缓存清空Useru3=mapper.getUser(1);// 再次查询数据库

三、二级缓存(Mapper 级缓存 / Namespace 级缓存)

核心特点

  • 默认关闭,需要手动开启
  • 作用域:同一个 Mapper.xml(同一个 namespace)下的所有查询
  • 跨 SqlSession 共享
  • 线程安全(MyBatis 内部使用了同步机制或第三方缓存实现)

开启二级缓存的步骤(三种方式):

  1. 全局开启(mybatis-config.xml)
<settings><settingname="cacheEnabled"value="true"/></settings>
  1. Mapper 级别开启(最常用)
<!-- 在 Mapper.xml 文件顶部 --><cacheeviction="LRU"<!--回收策略:LRU、FIFO、SOFT、WEAK-->flushInterval="60000"<!-- 刷新间隔(毫秒),不写表示永不过期 -->size="512"<!-- 缓存最大对象数 -->readOnly="true"<!-- 是否只读(true 性能更高,但对象不可修改) -->/>
  1. 单个查询使用二级缓存
<selectid="getUser"resultType="User"useCache="true"flushCache="false">select * from user where id = #{id}</select>

readOnly 的重要性

  • readOnly=“true”:MyBatis 直接返回缓存对象引用(性能最高,但不能修改对象)
  • readOnly=“false”(默认):MyBatis 会序列化 + 反序列化生成新对象(安全但性能稍差)

推荐:大多数业务场景建议readOnly="true",除非你明确需要修改返回的对象。

四、MyBatis 二级缓存常见问题与解决方案

  1. 脏读 / 数据不一致
    原因:一个命名空间下的 update 会清空整个 namespace 的二级缓存
    解决:使用分布式缓存(Redis、Ehcache) + 合理的缓存 Key 设计

  2. 缓存穿透 / 缓存雪崩
    解决:缓存空值、设置合理过期时间

  3. 多表关联查询缓存失效
    解决:尽量把关联查询拆分成单表查询,或使用 Caffeine / Redis 做细粒度缓存

  4. Spring + MyBatis 二级缓存失效
    原因:Spring 事务管理器每次 commit 都会清空一级缓存,二级缓存也可能受影响
    解决:使用 MyBatis 官方的二级缓存 + 分布式缓存方案

五、现代项目中 MyBatis 缓存的真实用法(2025–2026)

场景推荐做法说明
小型项目、查询频繁开启一级缓存 + 局部二级缓存简单有效
中大型项目关闭 MyBatis 二级缓存容易脏读、难以维护
高并发、分布式使用 Redis / Caffeine 做业务缓存手动 put/get,细粒度控制
热点数据(配置、字典表)Redis + MyBatis-Plus 缓存注解更现代、更可控
复杂查询关闭所有缓存 + 手动缓存避免各种奇怪问题

一句话总结

一级缓存是 SqlSession 的“临时记忆”,默认开启,适合同一个事务内的重复查询;
二级缓存是 Mapper 的“共享记忆”,默认关闭,适合读多写少的场景,但现代项目更倾向于关闭 MyBatis 自带二级缓存,转而使用业务层缓存(Redis、Caffeine)来实现更细粒度、更可控的缓存策略。

如果你想继续聊以下任一方向,可以告诉我:

  • MyBatis 二级缓存的源码实现细节(Cache、PerpetualCache、LruCache)
  • 如何在 Spring Boot 中优雅关闭 / 使用 MyBatis 二级缓存
  • Redis 作为 MyBatis 二级缓存的完整方案(mybatis-redis-cache)
  • MyBatis-Plus 缓存机制与原生 MyBatis 的对比
  • 实际项目中缓存踩过的坑与解决方案

继续写开发日记~

http://www.jsqmd.com/news/373684/

相关文章:

  • AWPortrait-Z人像生成避坑:负面提示词冲突检测与修正方法论
  • Lychee-Rerank-MM保姆级教程:Gradio界面上传限制解除与大文件支持
  • 通义千问1.5-1.8B-Chat-GPTQ-Int4开源应用:科研论文阅读助手本地部署
  • Git-RSCLIP在嵌入式设备上的轻量化部署方案
  • 基于.NET的EasyAnimateV5-7b-zh-InP桌面应用开发指南
  • RetinaFace在智能家居中的创新应用
  • ChatGLM-6B API开发指南:快速接入智能对话功能
  • Youtu-2B实战案例:中小企业智能客服系统搭建详解
  • 计算机网络监控:Cosmos-Reason1-7B智能分析实践
  • StructBERT情感分类模型实测:电商评论分析效果惊艳
  • Jimeng LoRA在数据结构优化中的应用:提升模型推理效率
  • 2026低空经济新篇章:工业级无人机崛起,西安迅影领跑巡检应急赛道 - 深度智识库
  • 浦语灵笔2.5-7B效果实测:这些惊艳的图片识别案例你也能做
  • Claude与Shadow Sound Hunter技术对比:代码生成能力评测
  • 3D砂型打印机哪个品牌好?2026十大品牌权威推荐与选购指南 - 匠言榜单
  • 一键去除复杂背景!AI净界RMBG-1.4使用指南
  • 长沙3家GEO优化公司实测:跨境企业专属,谁能兼顾本地+海外流量 - 亿仁imc
  • Git-RSCLIP模型YOLOv5目标检测集成方案
  • Qwen3-TTS-12Hz-1.7B-VoiceDesign 异常处理:常见生成问题排查
  • 5分钟搞定Qwen3-TTS部署:新手友好语音合成方案
  • EmbeddingGemma-300m在舆情监控系统中的应用
  • Qwen3-ASR-1.7B歌声识别效果展示:带背景音乐歌曲转写实测
  • LFM2.5-1.2B-Thinking使用技巧:让AI为你写文案
  • DCT-Net人像处理多场景:毕业季集体照卡通化、公司年会趣味头像墙
  • Qwen-Image-EditGPU算力适配:4090D下batch_size=1时显存占用精确测量报告
  • Llama-3.2-3B生产环境部署:高并发API服务搭建与压测报告
  • 快速部署PETRV2-BEV模型:星图AI平台一步到位
  • InstructPix2Pix社交应用:一键生成惊艳朋友圈照片
  • 10步极速出图!Qwen-Image-2512文生图保姆级教程
  • 零基础教程:用ollama快速玩转LFM2.5-1.2B文本生成