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

相关推荐
程序员侠客行19 小时前
Mybatis连接池实现及池化模式
java·后端·架构·mybatis
Honmaple19 小时前
QMD (Quarto Markdown) 搭建与使用指南
后端
PP东20 小时前
Flowable学习(二)——Flowable概念学习
java·后端·学习·flowable
invicinble20 小时前
springboot的核心实现机制原理
java·spring boot·后端
全栈老石20 小时前
Python 异步生存手册:给被 JS async/await 宠坏的全栈工程师
后端·python
space621232720 小时前
在SpringBoot项目中集成MongoDB
spring boot·后端·mongodb
Tony Bai21 小时前
再见,丑陋的 container/heap!Go 泛型堆 heap/v2 提案解析
开发语言·后端·golang
寻找奶酪的mouse21 小时前
30岁技术人对职业和生活的思考
前端·后端·年终总结
梦想很大很大21 小时前
使用 Go + Gin + Fx 构建工程化后端服务模板(gin-app 实践)
前端·后端·go
毅炼1 天前
Java 基础常见问题总结(4)
java·后端