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

相关推荐
iOS开发上架哦24 分钟前
iOS逆向工程:详细解析ptrace反调试机制的破解方法与实战步骤
后端·ios
程序员阿明42 分钟前
spring boot3识别PDF图纸
java·spring boot·后端·pdf
JuiceFS1 小时前
浅析 Amazon S3 Files:工作机制、性能边界与 JuiceFS 对比
后端
XPoet1 小时前
AI 编程工程化:MCP——给你的 AI 员工打通外部能力
前端·后端·ai编程
kiku18181 小时前
keepalived高可用与负载均衡
后端·github·lvs
Leo8992 小时前
mysql 从零单排之MVCC
后端
GreatSQL2 小时前
参数配置不当导致GreatSQL异步复制IO线程中断
后端
老马95272 小时前
opencode3-我的能力超乎你的想象
人工智能·后端
weixin_408099672 小时前
【企业级方案】财务自动化:OCR发票识别 + 自动录入系统完整实现(附代码与落地架构)
后端·ocr·api·发票 ocr 识别·发票自动录入系统·发票识别 api·财务自动化
千寻简2 小时前
一个让 Claude Code 顺手很多的状态栏插件:claude-hud
前端·后端