这篇“MySQL死锁场景实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MySQL死锁场景实例分析”文章吧。session1session2begin;begin;select * from dl where a=1 for update;…1 row in set (0.00 sec)select * from dl where a=2 for update;…1 row in set (0.00 sec)select * from dl where a=2 for update;/* SQL1 */(等待)(session2 提示死锁回滚后,SQL1 成功返回结构)select * from dl where a=1 for update;ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transactioncommit;commit;session1 在等待 session2 释放 a=2 的行锁,而 session2 在等待 session1 释放 a=1 的行锁。两个 session 互相等待对方释放资源,就进入了死锁状态。session1session2begin;begin;select * from dl where a=1 for update; … 1 row in set (0.00 sec)select * from dl_1 where a=1 for免费云主机域名 update; … 1 row in set (0.00 sec)select * from dl_1 where a=1 for update;/* SQL2 */ 等待(session2 提示死锁回滚后,SQL1 成功返回结构)select * from dl where a=1 for update; ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transactioncommit;commit;这个实验也是两个 session 互相等待对方释放资源,就进入了死锁状态。session1session2set session transaction_isolation=’REPEATABLE-READ’; /* 设置会话隔离级别为 RR */set session transaction_isolation=’REPEATABLE-READ’; /* 设置会话隔离级别为 RR */begin;begin;select * from dl where a=1 for update; … 1 row in set (0.00 sec)select * from dl where a=2 for update; … 1 row in set (0.00 sec)insert into dl(a,b,c) values (2,3,3);/* SQL1 */ 等待(session2 提示死锁回滚后,SQL1 成功返回结果)insert into dl(a,b,c) values (1,4,4);/* SQL2 */ ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transactioncommit;commit;由于 RR 隔离级别下存在间隙锁,可以知道 SQL1 需要等待 a=2 获得的间隙锁,而 SQL2 需要等待 a=1 获得的间隙锁,两个 session 互相等待对方释放资源,就进入了死锁状态。session1session2session3begin;insert into dl_insert(a,b,c) value (3,3,3);insert into dl_insert(a,b,c) value (3,3,3);/* 等待 */insert into dl_insert(a,b,c) value (3,3,3);/* 等待 */rollback;执行成功ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transaction这里需要注意的是,a 字段有唯一索引。当 session1 执行完 insert 语句,会在索引 a=3 上加记录锁,当 session2 执行同样的 insert 语句时,唯一键冲突,加上读锁;同样 session3 也会加上读锁。当 session1 回滚,session2 和 session3 都试图继续执行插入操作,都要加上写锁。此时两个 session 都要等待对方的行锁,因此出现了死锁。一些死锁场景就介绍到这里,当然,也欢迎各位补充其他的一些死锁场景。以上就是关于“MySQL死锁场景实例分析”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注百云主机行业资讯频道。
这篇文章主要讲解了“javascript是不是java的子集”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript是不是java的子集”吧! 不是。javascript和java是两套完全不同的语言…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。