news 2026/4/23 9:47:26

彻底讲清 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/4/23 9:46:46

PFC2D预制裂隙巴西劈裂试验模拟:探索岩石破裂奥秘

pfc2d预制裂隙的巴西劈裂试验模拟在岩石力学研究领域&#xff0c;巴西劈裂试验是一种常用的测试岩石抗拉强度的方法。而通过PFC2D&#xff08;Particle Flow Code in 2D&#xff09;软件对预制裂隙的巴西劈裂试验进行模拟&#xff0c;能帮助我们更深入理解岩石在复杂裂隙条件下…

作者头像 李华
网站建设 2026/4/18 2:45:29

16 位 SAR ADC 逐次逼近型 ADC 模拟集成电路设计探秘

【16位SAR ADC 逐次逼近型ADC模拟集成电路设计】 16位SAR ADC 同步时序&#xff1b; 采样率1MHz&#xff1b; 动态比较器&#xff1b; 栅压自举采样开关&#xff1b; 测试电路&#xff1b; 精度为14.61&#xff1b; 台湾65nm工艺 下载后可直接使用&#xff0c;保证仿出正确波形…

作者头像 李华
网站建设 2026/4/23 9:46:40

超越宣传:基于数据与案例的软件人才外包服务商价值评估指南

随着企业技术架构复杂化与项目节奏敏捷化并行&#xff0c;组建高效、稳定的技术团队已成为核心挑战。软件人才外包公司作为企业获取弹性技术能力的关键渠道&#xff0c;其市场正伴随数字化转型浪潮快速演进。据工信部运行监测协调局发布的2025年数据显示&#xff0c;我国软件和…

作者头像 李华
网站建设 2026/4/19 14:10:53

MQ消息队列相关知识与对比

一、MQ相关的概念 1.1 什么是MQ? MQ&#xff0c;即Message Queue&#xff08;消息队列&#xff09;&#xff0c;是一种基于“生产者-消费者”模式的分布式通信中间件。从字面意思上看就个 FIFO 先入先出的队列&#xff0c;只不过队列中存放的内容是 message 而已&#xff0c…

作者头像 李华
网站建设 2026/4/18 1:39:29

基于SpringBoot实现的大学生创新创业交流与分享平台

系统介绍基于SpringBootVue实现的大学生创新创业交流与分享平台采用前后端分离的架构方式&#xff0c;系统设计了管理员、导师、学生三种角色&#xff0c;管理员实现了首页看板、学生管理、导师管理、项目类型、创业资讯、创业项目、活动类型、报名、系统管理、个人中心等模块。…

作者头像 李华