Kaze
Kaze
Published on 2023-10-20 / 57 Visits
0
0

21为什么我只改一行的语句,锁这么多?

文章地址

加锁规则

MySQL 后面的版本可能会改变加锁策略,所以这个规则只限于 5.x 系列 <=5.7.24,8.0 系列 <=8.0.13。

两个“原则”、两个“优化”和一个“bug”

原则 1:加锁的基本单位是 next-key lock。next-key lock 是前开后闭区间。

原则 2:查找过程中访问到的对象才会加锁。

优化 1:索引上的等值查询,给唯一索引加锁的时候,next-key lock 退化为行锁。

优化 2:索引上的等值查询,向右遍历时且最后一个值不满足等值条件的时候,next-key lock 退化为间隙锁。

一个 bug:唯一索引上的范围查询会访问到不满足条件的第一个值为止。

此bug在后续版本中已修复

分析加锁规则的时候可以用 next-key lock 来分析。但是要知道,具体执行的时候,是要分成间隙锁和行锁两段来执行的。


Comment