美文网首页
深入理解MySQL的间隙锁

深入理解MySQL的间隙锁

作者: 技术灭霸 | 来源:发表于2020-05-02 16:57 被阅读0次

    幻读产生原因及解决方法

    因为行锁只能锁住行,但是新插入记录这个动作,要更新的是记录之间的“间隙”。为了解决幻读问题,InnoDB 只好引入新的锁,也就是间隙锁 (Gap Lock)。

    什么是间隙锁

    间隙锁,锁的就是两个值之间的空隙,不允许两个值之间再插一个值。

    比如初始化插入了 6 个记录,这就产生了 7 个间隙。分别是 (-∞,0)、(0,5)、(5,10)、(10,15)、(15,20)、(20, 25)、(25, +supremum),间隙锁都是开区间


    image.png

    和行锁不一样的是,跟间隙锁存在冲突关系的,是“往这个间隙中插入一个记录”这个操作。间隙锁之间都不存在冲突关系。

    缺点:可能会导致同样的语句锁住更大的范围,影响了并发度。

    什么是next-key lock

    间隙锁和行锁合称 next-key lock,每个 next-key lock 是前开后闭区间。如果用 select * from t for update 要把整个表所有记录锁起来,就形成了 7 个 next-key lock,分别是 (-∞,0]、(0,5]、(5,10]、(10,15]、(15,20]、(20, 25]、(25, +supremum]。

    和间隙锁的最大区别是,next-key lock 为前开后闭区间,这样所有的next-key lock就可以把所有记录锁起来。

    间隙锁的加锁规则

    加锁规则里面,包含了两个“原则”、两个“优化”和一个“bug”

    • 原则 1:加锁的基本单位是 next-key lock。希望你还记得,next-key lock 是前开后闭区间。
    • 原则 2:查找过程中访问到的对象才会加锁。
    • 优化 1:索引上的等值查询,给唯一索引加锁的时候,next-key lock 退化为行锁。
    • 优化 2:索引上的等值查询,向右遍历时且最后一个值不满足等值条件的时候,next-key lock 退化为间隙锁。
    • 一个 bug:唯一索引上的范围查询会访问到不满足条件的第一个值为止

    相关文章

      网友评论

          本文标题:深入理解MySQL的间隙锁

          本文链接:https://www.haomeiwen.com/subject/hbgkghtx.html