MySQL---只操作同一条记录,也会发生死锁吗?

✅MySQL只操作同一条记录,也会发生死锁吗?

因为数据库的锁锁的是索引,并不是记录。

当我们在事务中,更新一条记录的时候,如果用到普通索引作为条件,那么会先获取普通索引的锁,然后再尝试获取主键索引的锁。

那么这个时候,如果刚好有一个线程,已经拿到了这条记录的主键索引的锁后,同时尝试在该事务中去拿该记录的普通索引的锁。

这时候就会发生死锁。

案例

sql 复制代码
update my_table set name = 'aska-2',age = 22 where name = "aska";

这个SQL会先对name加锁, 然后再回表对id加锁。

sql 复制代码
select * from my_table where id = 15 for update;


update my_table set age = 33 where name like "aska%";

以上SQL,会先获取主键的锁,然后再获取name的锁。

为了避免这种死锁情况的发生,可以在应用程序中设置一个规定的索引获取顺序,例如,只能按照主键索引->普通索引的顺序获取锁,这样就可以避免不同的线程出现获取不同顺序锁的情况,进而避免死锁的发生(靠SQL保证)。

相关推荐
Victor356几秒前
Redis(10)如何连接到Redis服务器?
后端
他日若遂凌云志2 小时前
深入剖析 Fantasy 框架的消息设计与序列化机制:协同架构下的高效转换与场景适配
后端
快手技术2 小时前
快手Klear-Reasoner登顶8B模型榜首,GPPO算法双效强化稳定性与探索能力!
后端
二闹2 小时前
三个注解,到底该用哪一个?别再傻傻分不清了!
后端
用户49055816081252 小时前
当控制面更新一条 ACL 规则时,如何更新给数据面
后端
林太白2 小时前
Nuxt.js搭建一个官网如何简单
前端·javascript·后端
码事漫谈2 小时前
VS Code 终端完全指南
后端
该用户已不存在3 小时前
OpenJDK、Temurin、GraalVM...到底该装哪个?
java·后端
怀刃3 小时前
内存监控对应解决方案
后端
码事漫谈3 小时前
VS Code Copilot 内联聊天与提示词技巧指南
后端