在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

初学者从源码理解MySQL死锁问题

112次阅读
没有评论

共计 1492 个字符,预计需要花费 4 分钟才能阅读完成。

自动写代码机器人,免费开通

通过好多个深夜艰难的单步调试,终于找到了一个理想的断点,可以看到大部分获取锁的过程
代码在 lock0lock.c 的 static enum db_err lock_rec_lock() 函数中,这个函数会显示,获取锁的过程,以及获取锁成功与否。

场景 1:通过主键进行删除

表结构

CREATE TABLE `t1` (`id` int(11) NOT NULL AUTO_INCREMENT,
 `name` varchar(10) NOT NULL DEFAULT '',
 PRIMARY KEY (`id`)
) ENGINE=InnoDB;
delete from t1 where id = 10;

初学者从源码理解 MySQL 死锁问题

可以看到,对索引 PRIMARY 加锁,mode = 1027,1027 是什么意思呢?1027 =  LOCK_REC_NOT_GAP + LOCK_X(非 gap 的记录锁且是 X 锁)

过程如下

初学者从源码理解 MySQL 死锁问题

结论:根据主键 id 去删除数据,且没有其它索引的情况下,此 SQL 只需要在 id = 10 这条记录上对主键索引加 X 锁即可

场景 2:通过唯一索引进行删除

表结构做了微调,增加了 name 的唯一索引

CREATE TABLE `t2` (`id` int(11) NOT NULL AUTO_INCREMENT,
 `name` varchar(10) NOT NULL DEFAULT '',
 PRIMARY KEY (`id`),
 UNIQUE KEY `uk_name` (`name`)
INSERT INTO `t2` (`id`, `name`) VALUES 
 (1,'M'),
 (2,'Y'),
 (3,'S'),
 (4,'Q'),
 (5,'L');
测试 sql 语句
delete from t2 where name = "Y"

来看实际源码调试的结果

第一步:

初学者从源码理解 MySQL 死锁问题

第二步:

初学者从源码理解 MySQL 死锁问题

结论:这个过程是先对唯一键 uk_name 加 X 锁,然后再对聚簇索引(主键索引)加 X 锁

过程如下

初学者从源码理解 MySQL 死锁问题

场景 3:通过普通索引进行删除

CREATE TABLE `t3` (`id` int(11) NOT NULL AUTO_INCREMENT,
 `name` varchar(10) NOT NULL DEFAULT '',
 PRIMARY KEY (`id`),
 KEY `idx_name` (`name`) 
INSERT INTO `t3` (`id`, `name`) VALUES 
 (1,'N'),
 (2,'G'),
 (3,'I'),
 (4,'N'),
 (5,'X');
测试语句:delete from t3 where name = "N";

调试过程如图:

初学者从源码理解 MySQL 死锁问题

结论:通过普通索引进行更新时,会对满足条件的所有普通索引加 X 锁,同时会对相关的主键索引加 X 锁

过程如下

初学者从源码理解 MySQL 死锁问题

场景 4:不走索引进行删除

CREATE TABLE `t4` (`id` int(11) NOT NULL AUTO_INCREMENT,
 `name` varchar(10) NOT NULL DEFAULT '',
 PRIMARY KEY (`id`)
INSERT INTO `t4` (`id`, `name`) VALUES 
 (1,'M'),
 (2,'Y'),
 (3,'S'),
 (4,'Q'),
 (5,'L');
delete from t4 where name = "S";

初学者从源码理解 MySQL 死锁问题

初学者从源码理解 MySQL 死锁问题

总共有 5 把 X 锁,剩下的 3 把就不一一放上来了

结论:不走索引进行更新时,sql 会走聚簇索引(主键索引)对全表进行扫描,因此每条记录,无论是否满足条件,都会被加上 X 锁。还没完 …

但是为了效率考量,MySQL 做了优化,对于不满足条件的记录,会在判断后放锁,最终持有的,是满足条件的记录上的锁,但是不满足条件的记录上的加锁 / 放锁动作不会省略。

过程如下

初学者从源码理解 MySQL 死锁问题

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持丸趣 TV。

向 AI 问一下细节

丸趣 TV 网 – 提供最优质的资源集合!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-18发表,共计1492字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 人人添人人澡人人澡人人人人 | 丰满少妇69激情啪啪无 | 色黄大色黄女片免费看软件 | 免费可以看黄的视频 s色 | 久久露脸| 国产一级在线免费观看 | 韩产日产国产欧产 | 亚洲男人的天堂网站 | 日本黄网站三级三级三级 | 国产网红无码精品视频 | 亚洲在线一区 | 亚洲精品suv精品一区二区 | 青青青国产精品手机在线观看 | 亚洲毛片免费看 | 欧美无限看 | 久久精品国产亚洲婷婷 | 又污又爽又黄的网站 | 国产精品玖玖玖影院 | 日本在线观看成人小视频 | 日韩美女一级视频 | 欧美色综合久久 | 无码h黄动漫在线播放网站 无码h黄肉3d动漫在线观看 | 久久99热精品免费观看动漫 | 国产露脸对白porny | 99在线视频免费观看 | 国产初高中生视频在线观看 | 国产日韩精品欧美一区灰灰 | 后入内射欧美99二区视频 | 在线精品国产一区二区三区 | 一级毛片一 | 久久中文字幕无码中文字幕有码 | 亚洲乱色熟女一区二区三区麻豆 | 狠狠综合久久av一区二区 | 在线观看偷拍视频一区 | 国产亚洲精品激情一区二区三区 | 亚洲综合精品成人啪啪 | 国产精品久久无码不卡黑寡妇 | 免费看成人频视在线视频 | 国产精品成人不卡在线观看 | 黄色免费视频 | 国产精品亚洲午夜一区二区三区 |