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

相关推荐
追逐时光者7 分钟前
小伙伴们学习 C#/.NET 相关技术栈的学习心得和路线
后端·.net
gelald16 分钟前
Spring Security 核心组件
后端·spring
码事漫谈32 分钟前
Blazor现状调研分析:2025年全栈开发的新选择
后端
码事漫谈33 分钟前
C++的开发难点在哪里?
后端
刘一说1 小时前
Spring Boot 应用的指标收集与监控体系构建指南
java·spring boot·后端
冰_河2 小时前
《Nginx核心技术》第11章:实现MySQL数据库的负载均衡
后端·nginx·架构
weixin_436525072 小时前
SpringBoot 单体服务集成 Zipkin 实现链路追踪
java·spring boot·后端
q***78372 小时前
【玩转全栈】----Django制作部门管理页面
后端·python·django
Yeats_Liao3 小时前
时序数据库系列(八):InfluxDB配合Grafana可视化
数据库·后端·grafana·时序数据库
q***7484 小时前
Spring Boot环境配置
java·spring boot·后端