当前位置: 首页 > news >正文

MySQL中死锁

数据库的死锁是指不同的事务在获取资源时相互等待,导致无法继续执行的一种情况。当发生死锁时,数据库会自动中断其中一个事务,以解除死锁。在数据库中,事务可以分为读事务和写事务。读事务只需要获取读锁,而写事务需要获取写锁。当多个事务同时操作同一组数据时,可能会引发死锁的出现

MySQL中哪些情况会发生死锁

当一个事务同时更新多个表并且使用了不同的顺序,可能会导致死锁的发生。例如,事务A首先更新表X,然后获取锁,并在未释放锁的情况下尝试更新表Y;而事务B首先更新表Y,然后获取锁,并在未释放锁的情况下尝试更新表X。这种情况下,两个事务会相互等待对方的锁释放,从而形成死锁。

发生死锁的举例

假设有两个用户同时操作一个银行账户表,他们分别要进行转账操作。

用户A执行如下事务:

BEGIN;UPDATE accounts SET balance = balance - 1 WHERE id = 1;UPDATE accounts SET balance = balance +1 WHERE id = 2;COMMIT

用户B执行如下事务:

BEGIN;UPDATE accounts SET balance = balance - 1 WHERE id = 2;UPDATE accounts SET balance = balance + 1 WHERE id = 1;COMMIT

在并发执行时,可能会出现以下情况:

用户A执行了更新id=1的记录(得到锁1)

同时用户B 执行了更新id=2的记录(得到锁2)。

用户A执行了更新id=2的记录(获取锁2,等B释放)

同时用户B 执行了更新id=1的记录(准备获取锁1,等A释放)

由于用户A和用户B都在等待对方所持有的锁,导致了死锁的发生。

这种情况下,MySQL会自动选择一个事务作为死锁牺牲者,并回滚该事务以解开死锁

http://www.lryc.cn/news/193828.html

相关文章:

  • 【LeetCode刷题(数据结构)】:给定一个链表 每个节点包含一个额外增加的随机指针 该指针可以指向链表中的任何节点或空节点 要求返回这个链表的深度拷贝
  • uniapp封装loading 的动画动态加载
  • Kopler.gl笔记:可视化功能总览
  • rust学习Cell、RefCell、OnceCell
  • 基于SSM的摄影约拍系统
  • 分析智能平台VMware Greenplum 7 正式发布!
  • 动态规划算法(3)--0-1背包、石子合并、数字三角形
  • Linux C/C++ 嗅探数据包并显示流量统计信息
  • Vitis导入自制IP导致无法构建Platform
  • SQLAlchemy 使用封装实例
  • Android Framework通信:Binder
  • 如何用精准测试来搞垮团队?
  • 暴力递归转动态规划(十)
  • 深度学习-房价预测案例
  • 【26】c++设计模式——>命令模式
  • ElasticSearch容器化从0到1实践(一)
  • 【Vue面试题二十四】、Vue项目中有封装过axios吗?主要是封装哪方面的?
  • 旅游票务商城小程序的作用是什么
  • LabVIEW在安装了其它的NI软件之后崩溃了
  • 基于Java的个人健康管理系统设计与实现(源码+lw+部署文档+讲解等)
  • nginx https的配置方法
  • 使用WebDriver采样器将JMeter与Selenium集成
  • flink教程
  • 视频监控系统/安防视频平台EasyCVR广场视频细节优化
  • 电脑上播放4K视频需要具备哪些条件?
  • 测试除了点点点,还有哪些内容呢?
  • HTTP的本质理解
  • 微信小程序获取公众号的文章
  • 【算法|动态规划No.20】leetcode416. 分割等和子集
  • 深入解析C语言中的strstr函数