我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL45讲之InnoDB加锁规则 - flowers

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL45讲之InnoDB加锁规则 - flowers

MySQL45讲之InnoDB加锁规则 - flowers

本文介绍 MySQL InnoDB 的加锁规则,以及分析加锁时,一些需要注意的点。

前言

本文介绍 MySQL InnoDB 的加锁规则,以及一些需要注意的点。

总结

两个原则,两个优化,一个 bug:

原则1:加锁的基本单位是 next-key 锁,是一个前开后闭区间
原则2:查找过程中访问到的记录才会加锁

优化1:索引的等值查询,唯一索引加锁时,next-key 会退化为行锁
优化2:索引的等值查询,向右遍历时且最后一个值不符合时,最后一个 next-key 会退化为间隙锁

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

注意,以上的加锁规基于版本 MySQL 5.x <= 5.7.24,8.x <= 8.0.13

注意

lock in share mode 和 for update 的区别

使用 lock in share mode 上锁读时,可以进行索引覆盖,那么只会对覆盖索引树上锁,而不会对主键索引树上锁。使用 for update 上锁读时,系统认为接下来需要进行更新操作,所以会给符合条件的记录加上行锁。

这个指导我们,如果想用 lock in share mode 加读锁来避免记录被更新,那么需要避免索引覆盖的情况,否则通过主键索引还是可以修改记录。

使用 limit 可以减小加锁范围

当对 limit 数量的记录执行完操作后,将不再扫描后续的记录,也就不会再加锁。

虽然分析加锁区间用 next-key,但注意 next-key 是行锁和间隙锁的组合

看下图的事务流程:

死锁示例

你或许会疑问,session B 不是没有申请到 next-key 么。

是这样的,申请 next-key 分为两步,session B 首先申请 (5,10)的间隙锁,申请成功;然后申请 c=10 的行锁,阻塞,即申请 next-key 阻塞是阻塞在申请行锁的时候。因为 session B 申请了(5,10)的间隙锁,所以 session A 插入(8,8,8)阻塞。

参考

  • [1] 为什么我只改一行的语句,锁这么多

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL45讲之InnoDB加锁规则 - flowers

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL45讲之InnoDB加锁规则 - flowers

本文介绍 MySQL InnoDB 的加锁规则,以及分析加锁时,一些需要注意的点。 前言本文介绍 MySQL InnoDB 的加锁规则,以及一些需要注意的点。总结两个原则,两个优化,一个 bug:原则1:加锁的基本单位是 next-key 锁,是一个前开
MySQL45讲之InnoDB加锁规则 - flowers
2018-08-28

MySQL45讲之InnoDB刷脏策略 - flowers

本文介绍 InnoDB 的刷脏控制策略,它是如何控制刷脏速率的,以及一些相关参数。 前言本文介绍 InnoDB 的刷脏控制策略,它是如何控制刷脏速率的,以及一些相关参数。意义了解 MySQL 的刷脏策略有什么意义?当一条正确的 SQL 执行时偶尔延迟较高
MySQL45讲之InnoDB刷脏策略 - flowers
2018-05-10

【MySQL】说透锁机制(一)行锁 加锁规则 之 等值查询

文章目录 前言一、共享锁(S)和排它锁(X)二、行锁的3种算法Record LockGap LockNext-key Lock 三、加锁规则 之 等值查询分析数据准备3.1 聚集索引有匹配索引无匹配索引 3.2 唯一索引有
2023-08-18

【MySQL】说透锁机制(二)行锁 加锁规则 之 范围查询(你知道会锁表吗?)

本文会按照 聚集集索->唯一索引->普通索引 的顺序 地毯式分析 范围查询中 、、>、>= 的行锁情况,锁表分析在唯一索引 章节,万字长文,力求分析全面,很硬核全网独一份,记得收藏! 当然如果落下什么欢迎大家评论指出! 前文回顾 在上
2023-08-16

编程热搜

目录