尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

彻底讲清 MySQL InnoDB 锁机制:从 Record 到 Next-Key 的全景理解

彻底讲清 MySQL InnoDB 锁机制:从 Record 到 Next-Key 的全景理解
📅 发布时间:2026/6/18 17:56:51

在真实业务中,你遇到的大多数 MySQL 性能问题、死锁问题,几乎都与“锁”有关。但很多工程师对锁的理解停留在碎片层面:
知道“行锁”“间隙锁”“next-key-lock”,但不知道SQL 是如何触发这些锁的、锁到底锁在哪里、为什么会锁这么多。

这一篇文章,我会用工程化思维,带你一次性理解InnoDB 锁机制的全景图。

看完以后,你将具备:

✔ 能看懂锁的真实作用
✔ 能从 SQL 推断出锁范围
✔ 能解释死锁发生原因
✔ 能在面试中条理清晰地讲出锁机制


一、为什么 InnoDB 的锁机制这么复杂?

MySQL 采用MVCC + 锁实现事务隔离,其中最关键的隔离级别是:

  • RC:读已提交

  • RR:可重复读(默认)

RR 是企业最常见的隔离级别,它要解决“幻读”问题。
于是有了三个锁:

  • 记录锁(Record Lock)

  • 间隙锁(Gap Lock)

  • Next-Key Lock(Record + Gap)

所有复杂问题都来自这个组合。


二、InnoDB 的三种核心锁(理解它们的作用和触发条件)

Record Lock:真实行上的锁

锁的对象:一条真实存在的记录
触发场景:精确命中唯一索引

例如:

SELECT * FROM user WHERE id = 10 FOR UPDATE;

只锁(10]—— 单条记录。

特点:不会锁间隙,因此不会阻止插入。


Gap Lock:只锁“间隙”,不锁数据

作用:阻止“间隙内插入新数据”,防止幻读。

例如:
索引中已有值:

10 --- 20 --- 30

SQL:

SELECT * FROM user WHERE age > 20 FOR UPDATE;

Gap Lock 会锁住:

(20, 30) (30, +∞)

重点:Gap Lock 不锁记录,只锁区间。


Next-Key Lock:Record + Gap 的组合锁

RR 下范围查询的默认锁模式:

(prev_key, record_key]

例如:(假设索引有 10、20、30)

SELECT * FROM t WHERE age BETWEEN 15 AND 25 FOR UPDATE;

锁住的区间:

(10,20] (20,30]

作用:
✔ 锁住命中的记录
✔ 锁住记录前的 gap → 阻止插入

这就是为什么 RR 隔离级别能规避幻读。


三、锁到底由哪些 SQL 触发?

“ SQL → 锁类型” 映射表:

SQL 场景索引情况锁类型原因
WHERE id = ?(唯一键)精确命中Record Lock不需要锁 gap
WHERE id = ?(普通索引)精确匹配,但非唯一Next-Key Lock防止幻读
WHERE age > ?/< ?范围扫描Next-Key Lock必须锁 gap
BETWEEN范围查询范围扫描Next-Key Lock防止插入
无索引过滤全表扫描大量 Record Lock每条记录都会被锁
LIKE '%abc'无法走索引表锁风险全表扫描

一句话总结:

能精确锁住记录 → Record Lock
需要范围扫描 → Next-Key Lock
范围扫描一定会锁 gap → Gap Lock


四、锁具体加在什么区间?

假设索引中有如下值:

10 ---- 20 ---- 30 ---- 40

来看不同 SQL 加的锁👇

WHERE id = 20 FOR UPDATE

锁:

(10, 20]

但如果字段是主键/唯一键,会优化成:

[20]

WHERE id > 20 FOR UPDATE

锁:

(20,30) (30,40) (40,+∞)

WHERE id BETWEEN 15 AND 35 FOR UPDATE

锁:

(10,20] (20,30] (30,40]

无索引条件

SELECT * FROM user WHERE name='xxx' FOR UPDATE;

锁住所有记录:

[10], [20], [30], [40]

→ 大量锁冲突发生的根源。


五、总结

  1. InnoDB 的锁永远基于索引。

  2. 无法精确匹配记录,就会使用 Next-Key Lock。

  3. 范围查询一定会带 gap 锁。

掌握这三点后,死锁、锁等待、幻读问题都能一眼看穿。

相关新闻

  • MCU的启动流程你了解么?
  • I2C通信最全面的讲解:从协议到硬件设计
  • 【题解】Luogu P10752 [COI 2024] Sirologija

最新新闻

  • 国内主流打包机厂家实测排行 适配电商物流多场景 - 起跑123
  • 终端(Terminal)通俗完整讲解
  • 车载雷达架构迭代|全网量产复盘 场景反向定义ODD边界、L2-L4全域硬件升级、分布式转集中架构迭代、多雷达时序融合、整车感知全套工程复现
  • Windows系统优化神器:3分钟让你的电脑焕然一新
  • 开源AI创作平台:如何用自由工具释放你的多模态创意潜力?
  • 揭秘魔方终极解法:Python Kociemba算法库完整指南

日新闻

  • 2026年不锈钢卷板厂家推荐排行榜:冷轧热轧/304/201不锈钢卷板,高颜值耐腐蚀源头厂家实力精选 - 企业推荐官【官方】
  • FLUX.1-dev FP8模型实战指南:24GB以下显卡高效部署方案
  • 2026佛山长途搬家价目表:跨省跨市搬家费用完整计算指南 - 从来都是英雄出少年

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号