news 2026/6/9 20:48:55

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
彻底讲清 MySQL InnoDB 锁机制:从 Record 到 Next-Key 的全景理解

在真实业务中,你遇到的大多数 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 锁。

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 18:43:06

Python优化内存占用的技巧

Python 是一门为了开发效率而生的语言&#xff0c;其自动内存管理机制让开发者无需手动申请和释放内存。这种便利并非没有代价&#xff0c;Python 对象通常比 C 或 C 中的对应结构消耗更多内存。在处理大规模数据或在资源受限的容器环境中运行服务时&#xff0c;内存溢出&#…

作者头像 李华
网站建设 2026/6/5 13:29:25

I2C通信最全面的讲解:从协议到硬件设计

IIC&#xff08; Inter-Integrated Circuit&#xff0c;or I2C&#xff09;协议是由飞利浦半导体&#xff08;现在的恩智浦半导体&#xff09;开发&#xff0c;并于1982年发布的一种串行、半双工总线&#xff0c;主要用于近距离&#xff0c;低速的芯片之间的通信&#xff1b;I2…

作者头像 李华
网站建设 2026/6/9 9:18:57

5 分钟快速入门 Gitlab CI/CD

&#x1f680; 快速掌握 GitLab CI/CD&#xff1a;自动化你的开发流程 GitLab CI/CD 是一个功能强大的工具&#xff0c;它内置于 GitLab 中&#xff0c;用于自动化你的软件构建、测试和部署流程。如果你希望提升开发效率、减少人为错误并实现持续集成/持续部署&#xff08;CI/…

作者头像 李华
网站建设 2026/6/9 3:57:31

毕业论文选题AI推荐:9大工具+热门方向合集

毕业论文选题AI推荐&#xff1a;9大工具热门方向合集 &#xfffd;&#xfffd; 核心AI工具对比速览 工具名称 核心功能 适用场景 生成速度 特色优势 aibiye 初稿生成/降重/格式优化 全学科通用 20-30分钟 支持理工科图表公式自动插入 aicheck 选题推荐/查重/AIGC检…

作者头像 李华
网站建设 2026/5/30 17:48:25

Java毕业设计做不出来可以找代做吗?

这是一个非常敏感且重要的问题&#xff0c;我需要给你最负责任、最真诚的回答。直接答案&#xff1a;强烈不建议&#xff0c;风险极高&#xff0c;有百害而无一利。我理解你现在可能感到焦虑和无助&#xff0c;但寻找代做是一条会让你陷入更大麻烦的危险捷径。让我详细分析一下…

作者头像 李华