当前位置: 首页
科技数码
面试官:什么是 Next-Key Lock?作用是什么?

面试官:什么是 Next-Key Lock?作用是什么?

热心网友 时间:2025-12-15
转载

Next-Key Lock 是 InnoDB 引擎行锁加间隙锁的组合,它锁住的是一个前开后闭的区间,消除了 REPEATABLE READ 隔离级别下的幻读问题。

Next-Key Lock 是 InnoDB存储引擎中非常基础也是非常重要的一个锁。今天来聊一聊Next-Key Lock。

首先我们回顾一下MySQL的事务隔离级别。

串行化(Serializable):事务对数据读写都是串行的。可重复读(Repeatable Read):事务执行过程中,多次读取同一行数据,读取结果一致。MySQL默认隔离级别就是可重复读。读已提交数据(Read Committed):事务执行过程中,如果有其他事务修改了数据并且提交事务,当前事务可以读取到最新提交的数据。读未提交数据(Read Uncommitted):事务执行过程中,可以读取到其他事务未提交的数据。

可重复读隔离级别解决了幻读问题,而解决的方式就是通过MVCC 和 Next-Key Lock。

幻读:同一事务内多次查询同一范围内的数据,因其他事务插入或删除符合条件的数据,导致事务在后面读取到的结果集不一样,像产生了幻觉。

介绍

Next-Key Lock是间隙锁(gap lock)和行锁(index-record lock)的组合。

行锁: 锁定索引中的某一条具体记录。间隙锁: 锁定索引记录之间的间隙,它锁定的是一个范围,这个范围内不存在数据。例如,如果锁定了(10, 20)这个范围,那其他事务就不能在这个范围内插入新记录。

一个 Next-Key Lock,也就是行锁加上该行之前的间隙锁,因此,它锁定的是一个前开后闭区间。

我们假设有一张表t,包含(id,a,b)3个字段,其中 id 是主键,字段 a 上面有普通索引,字段 b 没有索引。建表语句如下:

CREATE TABLE `t` ( `id` int(10) NOT NULL, `a` int(10) DEFAULT NULL, `b` int(10) DEFAULT NULL, PRIMARY KEY (`id`), KEY `idx_a` (`a`)) ENGINE=InnoDB;

表中有 4 条记录,分别(5,5,5),(10,10,10),(15,15,15),(20,20,20),那如果执行下面语句:

select * from t where id = 7 for update;

这样会对id= 10的记录加Next-Key Lock,锁定的是(5, 10]这个区间,也就是说,除了锁住id = 10这条记录(行锁),同时间隙锁锁住了 5 和 10 之间的间隙(5,10)。

而如果执行下面这条SQL,则会对整张表加Next-Key Lock,因为字段 c 没有索引,新插入的数据都可能包含 c = 6。加锁后,形成 5 个范围:

select * from t where c = 6 for update;

图片图片

加上了Next-Key Lock,可以阻止其他事务在被锁定的间隙中插入新的记录,从而保证了当前事务中多次执行相同查询时,不会有新的记录查出来,解决了幻读问题。

在可重复隔离级别下,执行下面几个SQL时,都可能会对扫描过程中访问到的记录加Next-Key Lock:

SELECT * from t where id =xxx FOR UPDATE;//id 不存在SELECT * from t where a =xxx FOR UPDATE;SELECT * from t where b =xxx FOR UPDATE;SELECT * from t where id BETWEEN 10 AND 20;SELECT * from t where id =xxx LOCK IN SHAREMODE;UPDATE t set b = xxx where id = yyy;DELETE from t where id = yyy;

非唯一索引和无索引的字段,都可能会匹配多条记录,所以会加Next-Key Lock。

那如果查询的id存在,还会加Next-Key Lock吗? 比如上面的表,执行SQL:

SELECT * from t where id = 10 for update;

答案是不会加Next-Key Lock,这个时候Next-Key Lock退化成了行锁。

查询语句符合下面三个条件时,Next-Key Lock会退化成行锁:

查询使用的是唯一索引;SQL条件是等值匹配(比如 WHERE unique_key = X);扫描到的记录确定存在。

如果上面 3 个条件有一个不符合 ,都会加 Next-Key Lock。

另一点,虽然Next-Key Lock是前开后闭区间,如果索引上等值查询向右遍历到最后一个值不满足等值条件,则退化为间隙锁。比如执行下面SQL:

SELECT * from t where id = 8 for update;

Next-Key Lock退化为间隙锁,加锁范围是(5,10)。id = 10的这条记录不影响其他事务修改操作。

优缺点

优点:解决了REPEATABLE READ隔离级别下幻读问题,有效保证了数据一致性。

缺点: 增加了锁的粒度,一定情况下会降低并发性能,并增加死锁发生的概率。因为多个事务可能以不同的顺序请求对重叠的间隙加锁,很容易造成死锁。

下面是一个死锁的案例,事务A准备插入一条(8,8,8)的记录,事务 B 准备插入一条(9,9,9)的记录,其他他们相互不影响,但加了 Next-Key Lock,就容易造成死锁。

这样两个事务都会加(5,10)这个间隙锁,最终相互等待,形成死锁。

为什么两个事务都可以加上间隙锁,因为间隙锁之间不会冲突。

总结

Next-Key Lock 是 InnoDB引擎行锁加间隙锁的组合,它锁住的是一个前开后闭的区间,消除了REPEATABLE READ隔离级别下的幻读问题。理解Next-Key Lock要把握两点:

可重复隔离级别下才会生效;锁住一个前开后闭的区间,但一定条件下可能退化成行锁或者间隙锁。
来源:https://www.51cto.com/article/822993.html

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
谷歌上诉称搜索成功源于创新而非排他协议

谷歌上诉称搜索成功源于创新而非排他协议

谷歌就反垄断裁决提起上诉,辩称其市场地位源于产品创新与持续投资,而非排他协议。谷歌强调与苹果的默认搜索协议是商业自主选择,未损害竞争,用户可自行更改搜索引擎。上诉旨在撤销要求其开放数据、分发竞品结果的整改措施。

时间:2026-05-23 09:47
美股芯片股大涨中概股普跌 美联储加息概率升至70%

美股芯片股大涨中概股普跌 美联储加息概率升至70%

美股三大指数集体收涨,道指创历史新高。芯片股表现强势,费城半导体指数创新高,高通暴涨超11%。中概股普遍承压,纳斯达克中国金龙指数下跌。美联储新主席就任,市场预期加息概率升至70%,为未来增添变数。

时间:2026-05-23 09:46
中国电动汽车欧洲市场份额首次突破15%

中国电动汽车欧洲市场份额首次突破15%

今年4月,中国品牌电动汽车在欧洲市场销量占比首次突破15%,比亚迪、奇瑞等销量同比激增。凭借性价比与智能化优势,中国电动车加速渗透欧洲,插电混动份额近29%。同期中国新能源乘用车出口40 6万辆,同比增长111 8%,出口占比首超一半,欧洲、巴西等地增长显著,彰显全球竞争力持续提升。

时间:2026-05-23 09:46
小米Vision Gran Turismo概念车国内首秀亮相北京车展

小米Vision Gran Turismo概念车国内首秀亮相北京车展

2026年北京车展上,小米汽车展示了新一代SU7、即将发布的YU7GT及国内首秀的VisionGranTurismo概念车。新一代SU7市场表现强劲,续航与性能突出;YU7GT定位纯电GTSUV,强调高性能与操控;概念车则探索空气动力学与智能交互。小米汽车产品矩阵日趋完整,交付能力显著,正从行业新兵成长为具备体系竞争力的玩家。

时间:2026-05-23 09:14
海狮05双动力车型贵阳上市 开启贵州新能源出行新篇章

海狮05双动力车型贵阳上市 开启贵州新能源出行新篇章

5月22日,比亚迪全新海狮05在贵阳上市,提供EV纯电与DM-i插混双动力系统,售价9 79万起。新车搭载第二代刀片电池与闪充技术,缓解续航焦虑,覆盖全场景出行。其采用海洋美学设计,配备智能座舱与场景化功能,旨在满足家庭及年轻用户多元化需求。

时间:2026-05-23 08:43
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程