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保证)。

相关推荐
脚踏实地的大梦想家1 分钟前
【Go】P11 掌握 Go 语言函数(二):进阶玩转高阶函数、闭包与 Defer/Panic/Recover
开发语言·后端·golang
用户685453759776944 分钟前
🔥 服务熔断降级:微服务的"保险丝"大作战!
后端
Tech有道44 分钟前
拼多多「面试官问我:LRU 和 LFU 你选谁?」我:看场景啊哥!😂
后端
用户685453759776944 分钟前
🎬 开场:RPC框架的前世今生
后端
王中阳Go背后的男人1 小时前
Docker磁盘满了?这样清理高效又安全
后端·docker
用户68545375977691 小时前
🎛️ 分布式配置中心:让配置管理不再是噩梦!
后端
CodeFans1 小时前
Spring 浅析
后端
李广坤1 小时前
Filter(过滤器)、Interceptor(拦截器) 和 AOP(面向切面编程)
后端
oak隔壁找我1 小时前
反向代理详解
后端·架构
YUELEI1181 小时前
Springboot WebSocket
spring boot·后端·websocket