加入收藏 | 设为首页 | 会员中心 | 我要投稿 惠州站长网 (https://www.0752zz.com.cn/)- 办公协同、云通信、物联设备、操作系统、高性能计算!
当前位置: 首页 > 建站 > 正文

两个小工具,MySQL死锁分析,新技能又Get!

发布时间:2019-07-12 07:35:40 所属栏目:建站 来源:58沈剑
导读:副标题#e# 数据库死锁,是最难调试与追踪的。 场景如下: 同一个表,事务内先插入一条记录,再更新这条记录,并发时会死锁。 并且能够复现。 可以通过什么工具模拟并发事务,查看信息,解决问题呢?这是今天要分享的内容。 一、前置准备 setsessiontransacti

再仔细一看:

  1. create table t ( 
  2. id int(20) primary key AUTO_INCREMENT, 
  3. cell varchar(20) unique 
  4. )engine=innodb; 

建表的时候cell定义的是字符串类型。

而更新的时候,

  1. update t set cell=456 where cell=55555555555; 

使用的是整数类型。

类型转换,会导致全表扫描,出现锁升级,锁住全部记录。

加上引号,再次通过explain验证一下:

  1. explain update t set cell= '456 ' where cell= '55555555555 '; 

两个小工具,MySQL死锁分析,新技能又Get!

果然印证了猜想:

  • type:range,变为了走索引的字符串比对,范围扫描;
  • possible_keys:cell,通过cell索引找到了记录;
  • key:cell,实际使用cell索引;
  • ref:const,使用了常量' 555'进行比对;
  • rows:1,预估读取行数是1;

这下全部可以解释了。

两个小工具,MySQL死锁分析,新技能又Get!

总结

就本例而言:需要注意字符串与整数之间的强制类型转换,有时候少一个引号,就会使得行锁升级为表锁。

死锁是MySQL中非常难调试的问题,常见的思路与方法有:

  • 通过多终端模拟并发事务,复现死锁;
  • 通过show engine innodb status; 可以查看事务与锁的信息;
  • 通过explain可以查看执行计划;

思路比结论更重要,希望大家有收获。

【本文为51CTO专栏作者“58沈剑”原创稿件,转载请联系原作者】

两个小工具,MySQL死锁分析,新技能又Get!

戳这里,看该作者更多好文

【编辑推荐】

  1. 科学家无法涉足的“黑暗世界”,被雪藏的军用数据等待新生
  2. 心里没点B树,怎能吃透数据库索引底层原理?
  3. 一文带你了解什么是数据挖掘
  4. 数据库允许空值(null),往往是悲剧的开始(1分钟系列)
  5. 这五种统计学概念,扫清数据科学之路“拦路虎”
【责任编辑:赵宁宁 TEL:(010)68476606】
点赞 0

(编辑:惠州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

推荐文章
    热点阅读