出处:http://www.jb51.net/article/51508.htm

MySQL死锁问题是很多程序员在项目开发中常遇到的问题,现就MySQL死锁及解决方法详解如下:

1、MySQL常用存储引擎的锁机制

MyISAM和MEMORY采用表级锁(table-level locking)

BDB采用页面锁(page-level locking)或表级锁,默认为页面锁

InnoDB支持行级锁(row-level locking)和表级锁,默认为行级锁

2、各种锁特点

表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低

行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高

页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般

3、各种锁的适用场景

表级锁更适合于以查询为主,只有少量按索引条件更新数据的应用,如Web应用

行级锁则更适合于有大量按索引条件并发更新数据,同时又有并发查询的应用,如一些在线事务处理系统

4、死锁

是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去。

表级锁不会产生死锁.所以解决死锁主要还是针对于最常用的InnoDB.

5、死锁举例分析

在MySQL中,行级锁并不是直接锁记录,而是锁索引。索引分为主键索引和非主键索引两种,如果一条sql语句操作了主键索引,MySQL就会锁定这条主键索引;如果一条语句操作了非主键索引,MySQL会先锁定该非主键索引,再锁定相关的主键索引。

在UPDATE、DELETE操作时,MySQL不仅锁定WHERE条件扫描过的所有索引记录,而且会锁定相邻的键值,即所谓的next-key locking。

例如,一个表db.tab_test,结构如下:

id:主键;

state:状态;

time:时间;

索引:idx_1 (state, time)

出现死锁日志如下:

原因分析:

当“update tab_test set state=1064,time=now() where state=1061 and time < date_sub(now(), INTERVAL 30 minute)”执行时,MySQL会使用idx_1索引,因此首先锁定相关的索引记录,因为idx_1是非主键索引,为执行该语句,MySQL还会锁定主键索引。

假设“update tab_test set state=1067,time=now () where id in (9921180)”几乎同时执行时,本语句首先锁定主键索引,由于需要更新state的值,所以还需要锁定idx_1的某些索引记录。

这样第一条语句锁定了idx_1的记录,等待主键索引,而第二条语句则锁定了主键索引记录,而等待idx_1的记录,这样死锁就产生了。

6、解决办法

拆分第一条sql,先查出符合条件的主键值,再按照主键更新记录:

至此MySQL死锁问题得以解决!

mysql 1061原因_MySQL死锁问题分析及解决方法实例详解(转)相关推荐

  1. net4.0 程序没反应_笔记本触摸板没反应原因 笔记本触摸板没反应解决方法【详解】...

    笔记本触摸板 使用起来虽然没有鼠标那样灵敏,但是只要用习惯了还是非常实用的,不知道你有没有出现过笔记本触摸板没反应的情况呢?相信使用久了,很多拥有 笔记本 的人都会出现这样的情况.那么, 笔记本触摸板 ...

  2. ensp启动设备蓝屏_戴尔笔记本蓝屏原因 戴尔笔记本蓝屏解决方法【详解】

    相信大家在使用笔记电脑的过程中都遇到过蓝屏的现象,比如在办公.看视频.玩游戏.安装驱动.重装系统后等等的过程中出现蓝屏现象,电脑蓝屏是件很苦恼的事,如果我们能掌握一些关于电脑蓝屏的小知识,一部分的蓝屏 ...

  3. mysql 查询 集合_MySQL使用集合函数进行查询操作实例详解

    本文实例讲述了MySQL使用集合函数进行查询操作.分享给大家供大家参考,具体如下: COUNT函数 SELECT COUNT(*) AS cust_num from customers; SELECT ...

  4. 计算机开机反复启动,电脑开机后反复重启原因 电脑开机后反复重启解决方法【详解】...

    电脑运用时间长了,或多或少都会出现一些问题.很多人都会遇到电脑开机反复重启的现象,现在我们一起从以下几方面去分析这种问题,希望对大家有所帮助. 1. 我们比较常见的系统重新启动问题就是操作系统文件遗失 ...

  5. php去除重复的数据保留一条,mysql查找删除重复数据并只保留一条实例详解

    有这样一张表,表数据及结果如下: school_id school_name total_student test_takers 1239 Abraham Lincoln High School 55 ...

  6. mysql添加新的实例_MySQL中添加新用户权限的实例详解

    有2个不同的方法增加用户:通过使用GRANT语句或通过直接操作MySQL授权表.比较好的方法是使用GRANT语句,因为他们是更简明并且好像错误少些. 下面的例子显示出如何使用MySQL客户安装新用户. ...

  7. mysql通过集合查询_MySQL使用集合函数进行查询操作实例详解

    本文实例讲述了MySQL使用集合函数进行查询操作.分享给大家供大家参考,具体如下: COUNT函数 SELECT COUNT(*) AS cust_num from customers; SELECT ...

  8. mysql 自动截断_MySql中关于超长自动截断的案例详解

    这篇文章主要介绍了MySql超长自动截断实例详解的相关资料,这里通过实例来说明如何实现自动截断的功能,需要的朋友可以参考下 MySql超长自动截断实例详解 小伙伴问到一个问题,为啥在项目中调用插入或者 ...

  9. php mysql 去重_mysql去重的两种方法实例详解

    这篇文章主要介绍了mysql去重的两种方法详解及实例代码的相关资料,这里对去重的两种方法进行了一一实例详解,需要的朋友可以参考下 mysql去重 方法一: 在使用MySQL时,有时需要查询出某个字段不 ...

最新文章

  1. 使用证书保护网站--兼谈证书服务器吊销列表的使用
  2. java hashmap 缓存
  3. 汇编语言Makefile
  4. linux定时任务的用法详解
  5. swiper鼠标hover停止自动轮播_swiper滑块组件
  6. 三十五岁后,如何自学WEB前端编程
  7. 基于id3算法根据房价数据进行画图预测python
  8. python小波分解与重构_python - 使用pyWavelets进行多级局部小波重构 - 堆栈内存溢出...
  9. 中的枚举属性函数_对于 JavaScript 中循环之间的技术差异分析
  10. LeetCode之罗马数字转整数
  11. acm集训训练赛(二)D题【并查集】
  12. python 微信扫码登录_python实现微信第三方网站扫码登录(Django)
  13. 计算机北桥芯片结构图,电脑主板芯片维修教程第一节:电脑主板你是否真的认识...
  14. 科研画图都用什么软件?
  15. tp6 导入excel表格
  16. win32反汇编初步探索及Onllydbg的使用
  17. 用texstudio写伪代码
  18. Halcon 排线检测|固定颜色检测
  19. 样式padding-left和margin-left有什么区别?(from baidu zidao)
  20. LAYUI表格自动渲染

热门文章

  1. MinkowskiEngine demo ModelNet40分类
  2. 客快物流大数据项目(五十二):根据数据库表及字段创建公共模块
  3. 2021年大数据ELK(二十四):安装Kibana
  4. git clean和git reset结合用法
  5. 量子力学在计算机上的应用,量子力学在医学科学中的应用
  6. TypeError: ‘instancemethod‘ object has no attribute ‘__getitem__‘
  7. 二叉树的遍历(递归与非递归)
  8. 如何参与贡献Dubbo社区
  9. Oracle Job定时任务的使用详解
  10. 将 instance 连接到 first_local_net - 每天5分钟玩转 OpenStack(82)