通过好多个深夜艰难的单步调试,终于找到了一个理想的断点,可以看到大部分获取锁的过程
代码在lock0lock.cstatic 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;

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

过程如下

结论:根据主键 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"

第一步:

第二步:

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

过程如下

场景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";

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

过程如下

场景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";

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

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

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

过程如下

更多相关文章

  1. 关于Android初学者的学习线路的相关知识
  2. 致Android初学者:如何学习Android开发
  3. android入门级小软件身高体重计算器源代码,初学者可以看看~
  4. 如何学习Android开发编程-初学者的5个步骤
  5. Android开发入门之路(初学者必读)
  6. 【Android(安卓)初学者】开发工具介绍:studio
  7. 对Android初学者学习中的几点建议
  8. 适于android初学者入门的资料集
  9. 对Android初学者学习中的几点建议

随机推荐

  1. 开始开发Android的使用Eclipse
  2. 记一次 Android(安卓)面试
  3. Android(安卓)OpenGLES2.0(九)——利用Open
  4. Android真的会凉吗?从现状和未来大趋势等
  5. Android页面去掉标题全屏的方法-第一次用
  6. Android Studio(五):修改Android Studio项
  7. android中java与js通信(可以用html来做页
  8. Android应用程序窗口(Activity)的测量(Measu
  9. TabHost布局及新浪式TabHost布局
  10. android英语字典(内含源码哦)