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

相关推荐
PH = 71 小时前
Spring AI整合聊天模型DeepSeek
java·spring boot·后端
计算机毕业设计小帅1 小时前
【2026计算机毕业设计】基于Springboot的医院信息管理系统
spring boot·后端·课程设计
IT_陈寒3 小时前
React Hooks 实战:这5个自定义Hook让我开发效率提升了40%
前端·人工智能·后端
开始学java3 小时前
异常机制-异常分类
后端
小虚竹and掘金3 小时前
Claude Sonnet 4.5 编程王位世袭罔替!全网首发最全1.3万字详细测评,国内直接使用
后端
做运维的阿瑞3 小时前
使用 Python 打造一个轻量级系统信息查看器
开发语言·后端·python·系统架构
起风了___4 小时前
Docker 一键部署指南:GitLab、Nacos、Redis、MySQL 与 MinIO 全解析
后端·docker
用户4099322502124 小时前
PostgreSQL视图不存数据?那它怎么简化查询还能递归生成序列和控制权限?
后端·ai编程·trae
karry_k4 小时前
CopyOnWriteArraySet
后端
spmcor4 小时前
NestJS 统一响应格式最佳实践:标准化 API 返回结构
后端