news 2026/5/1 6:08:20

MySQL,InnoDB的select为什么会阻塞insert?(第8讲,超硬核)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL,InnoDB的select为什么会阻塞insert?(第8讲,超硬核)

《数据库架构100讲》

8. InnoDB锁:记录锁,间隙锁,临键锁。

今天介绍InnoDB七种锁的最后三种:记录锁,间隙锁,临键锁。

MySQL的InnoDB的细粒度行锁,是它最吸引人的特性之一。InnoDB的细粒度锁,是实现在索引记录上的。

一,InnoDB的索引

InnoDB的索引有两类索引,聚集索引(Clustered Index)与普通索引(Secondary Index)。

InnoDB的每一个表都会有聚集索引:

1. 如果表定义了PK,则PK就是聚集索引;

2. 如果表没有定义PK,则第一个非空unique列是聚集索引;

3. 否则,InnoDB会创建一个隐藏的row-id作为聚集索引;

为了方便说明,后文都将以PK说明。

索引的结构是B+树,这里不展开B+树的细节,说几个结论:

1. 在索引结构中,非叶子节点存储key,叶子节点存储value;

2.聚集索引,叶子节点存储行记录(row);

画外音:所以,InnoDB索引和记录是存储在一起的,而MyISAM的索引和记录是分开存储的。

3.普通索引,叶子节点存储了PK的值;

画外音:

所以,InnoDB的普通索引,实际上会扫描两遍:

第一遍,由普通索引找到PK;

第二遍,由PK找到行记录;

索引结构,InnoDB/MyISAM的索引结构,如果大家感兴趣,未来撰文详述。

举个例子,假设有InnoDB表:

t(id PK, name KEY, sex, flag);

表中有四条记录:

1, shenjian, m, A

3, zhangsan, m, A

5, lisi, m, A

9, wangwu, f, B

以看到:

1. 第一幅图,id PK的聚集索引,叶子存储了所有的行记录;

2. 第二幅图,name上的普通索引,叶子存储了PK的值;

对于:

select * from t where name=’shenjian’;

1. 会先在name普通索引上查询到PK=1;

2. 再在聚集索引衫查询到(1,shenjian, m, A)的行记录;

下文简单介绍InnoDB七种锁中的剩下三种:

- 记录锁(Record Locks)

- 间隙锁(Gap Locks)

- 临键锁(Next-Key Locks)

为了方便讲述,如无特殊说明,后文中,默认的事务隔离级别为可重复读(Repeated Read, RR)。

二、记录锁(Record Locks)

记录锁,它封锁索引记录,例如:

select * from t where id=1 for update;

它会在id=1的索引记录上加锁,以阻止其他事务插入,更新,删除id=1的这一行。

需要说明的是:

select * from t where id=1;

则是快照读(SnapShot Read),它并不加锁,具体在《InnoDB的高并发,是不是因为MVCC?(第5讲)》中做了详细阐述。

三、间隙锁(Gap Locks)

间隙锁,它封锁索引记录中的间隔,或者第一条索引记录之前的范围,又或者最后一条索引记录之后的范围。

依然是上面的例子,InnoDB,RR:

t(id PK, name KEY, sex, flag);

表中有四条记录:

1, shenjian, m, A

3, zhangsan, m, A

5, lisi, m, A

9, wangwu, f, B

这个SQL语句

select * from t

where id between 8 and 15

for update;

会封锁区间,以阻止其他事务id=10的记录插入。

画外音:

为什么要阻止id=10的记录插入?

如果能够插入成功,头一个事务执行相同的SQL语句,会发现结果集多出了一条记录,即幻影数据。

间隙锁的主要目的,就是为了防止其他事务在间隔中插入数据,以导致“不可重复读”。

如果把事务的隔离级别降级为读提交(Read Committed, RC),间隙锁则会自动失效。

四、临键锁(Next-Key Locks)

临键锁,是记录锁与间隙锁的组合,它的封锁范围,既包含索引记录,又包含索引区间。

更具体的,临键锁会封锁索引记录本身,以及索引记录之前的区间。

如果一个会话占有了索引记录R的共享/排他锁,其他会话不能立刻在R之前的区间插入新的索引记录。

画外音:原文是说

If one session has a shared or exclusive lock on record R in an index, another session cannot insert a new index record in the gap immediately before R in the index order.

依然是上面的例子,InnoDB,RR:

t(id PK, name KEY, sex, flag);

表中有四条记录:

1, shenjian, m, A

3, zhangsan, m, A

5, lisi, m, A

9, wangwu, f, B

PK上潜在的临键锁为:

(-infinity, 1]

(1, 3]

(3, 5]

(5, 9]

(9, +infinity]

临键锁的主要目的,也是为了避免幻读(Phantom Read)。如果把事务的隔离级别降级为RC,临键锁则也会失效。

画外音:关于事务的隔离级别,以及幻读,之前的文章一直没有展开说明,如果大家感兴趣,后文详述。

今天的内容,主要对InnoDB的索引,以及三种锁的概念做了介绍。场景与例子,也都是最简单的场景与最简单的例子。

InnoDB的锁,与索引类型,事务的隔离级别相关,更多更复杂更有趣的案例,后续和大家介绍。

五、总结

1. InnoDB的索引与行记录存储在一起,这一点和MyISAM不一样;

2. InnoDB的聚集索引存储行记录,普通索引存储PK,所以普通索引要查询两次;

3.记录锁锁定索引记录;

4.间隙锁锁定间隔,防止间隔中被其他事务插入;

5.临键锁锁定索引记录+间隔,防止幻读;

知其然,知其所以然。

思路比结论更重要。

画外音:我学的MySQL知识基于5.6。

==全文完==

有架构合集吗?

《流量从10万到10亿,80个架构问题》

《关于即时通讯架构的一切!》

性格内向,能不能做到个人品牌?欢迎预约!

Q4内测了一个新产品,看普通人起号能否复制:

40来岁,我创业了,70天短视频行动营!

内测成绩不错,4周的时间全网流量结果为:

一班:32.5W(4周人均)

二班:41.4W(4周人均)

三班:45.3W(4周人均)

四班:41.3W(4周人均)

画外音:人均是什么概念?就是参与行动营的所有学员,4周人均流量为40W左右。

个人品牌,完全可以复制,关键就看个人勇气。

1月份启动二期,阅读原文一起参与!

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

构建‘动漫角色语音复活’平台粉丝上传台词生成经典重现

构建“动漫角色语音复活”平台:粉丝上传台词生成经典重现 在B站上,一位《火影忍者》的忠实粉丝上传了一段自制短片——画面中鸣人站在月光下说出那句经典的“我不会放弃的!”,声音却不再是原版声优竹内顺子的演绎,而是…

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

BBDown神器:小白也能轻松掌握的B站视频下载终极指南

你是否曾经遇到过这样的情况:看到B站上一个精彩的教学视频,想要反复观看学习,却因为网络不稳定或者担心视频被下架而焦虑?别担心,今天我要向你推荐一款神器级别的工具——BBDown,让你轻松搞定B站视频下载&a…

作者头像 李华
网站建设 2026/4/30 4:24:01

开发‘生日祝福生成器’朋友录音混合生成惊喜语音贺卡

开发“生日祝福生成器”:朋友录音混合生成惊喜语音贺卡 你有没有想过,给朋友做一张会“说话”的生日贺卡——不是AI机械朗读,而是用他妈妈的声音激动地说“宝贝生日快乐”,或者让那个平时冷淡的哥们儿突然温柔地祝你“天天开心”&…

作者头像 李华
网站建设 2026/4/17 10:58:50

TranslucentTB任务栏透明终极修复方案:Windows 11兼容性完整指南

TranslucentTB任务栏透明终极修复方案:Windows 11兼容性完整指南 【免费下载链接】TranslucentTB A lightweight utility that makes the Windows taskbar translucent/transparent. 项目地址: https://gitcode.com/gh_mirrors/tr/TranslucentTB 还在为Windo…

作者头像 李华
网站建设 2026/4/29 4:35:54

联动‘Unity游戏引擎’实现实时NPC语音生成基于IndexTTS

联动“Unity游戏引擎”实现实时NPC语音生成基于IndexTTS 在今天的开放世界游戏中,玩家早已不再满足于那些用固定语音反复念白的NPC。我们期待的是能根据情境变化语气、带有情绪起伏、甚至会因紧张而结巴的角色——就像真实的人类一样。然而,要实现这种级…

作者头像 李华
网站建设 2026/4/23 1:59:23

集成‘After Effects’动态图形与IndexTTS语音同步动画

集成“After Effects”动态图形与IndexTTS语音同步动画 在虚拟主播24小时不间断直播、AI生成短视频批量上线的今天,内容创作者面临的不再是“有没有声音”,而是“声音能不能严丝合缝地贴合画面节奏”。传统配音流程中,剪辑师常常需要反复拖动…

作者头像 李华