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

相关推荐
考虑考虑23 分钟前
Springboot捕获feign抛出的异常
spring boot·后端·spring
洛神灬殇25 分钟前
【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 时间事件处理部分)
redis·后端
DataFunTalk33 分钟前
Foundation Agent:深度赋能AI4DATA
前端·后端·算法
楽码36 分钟前
一文看懂隐藏功能!语言的逃逸分析
后端·go·编程语言
RunsenLIu1 小时前
基于Django实现的图书分析大屏系统项目
后端·python·django
Chandler241 小时前
Go:低级编程
开发语言·后端·golang
Asthenia04121 小时前
ArrayList与CopyOnWriteArrayList源码深度解析及面试拷打
后端
Asthenia04121 小时前
深入解析String、StringBuilder、StringBuffer与final修饰对象的问题
后端
Asthenia04121 小时前
Java数据类型的四类八种与拆装箱底层原理
后端
郭萌6962 小时前
Docker 安装陀螺匠教程
后端