大佬教程收集整理的这篇文章主要介绍了重新运行想要获取锁但等待另一个事务完成的选择查询,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
考虑我们有一个带有 datetiR_38_11845@e 列的表
表格:示例
现在,有两个并发事务使用以下查询获取行上的排他锁。
SELECT *
FROM sample
WHERE timestamp < '2021-02-26T10:50:00'
ORDER BY timestamp DESC
liMIT 1
FOR updatE;
因此,两个事务都将尝试获取同一行(第 1 行)的锁,其中一个会成功,而另一个会等待。
假设事务 A 能够获取锁,事务 A 要做的下一件事是插入一个带有时间戳 2021-02-26T10:30:00
的记录并提交。
现在,一旦事务 A 完成,事务 B 将获得第 1 行的锁,但现在数据发生了变化,准确的结果应该是第 3 行。
有没有办法使用行级锁来实现它?
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)
以上是大佬教程为你收集整理的重新运行想要获取锁但等待另一个事务完成的选择查询全部内容,希望文章能够帮你解决重新运行想要获取锁但等待另一个事务完成的选择查询所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。