- 39
- 0
事务A尝试进行加锁操作 select for update where xxx,但此时事务B已经加update锁,事务A会等待事务B释放锁再执行。
那么,如果事务B commit所作的改变,使得某些行数据不再符合事务A的where XXX条件,
那么此时会发生什么?事务A的select还会获取到这些数据吗?
0
打赏
收藏
点击回答
您的回答被采纳后将获得:提问者悬赏的 10 元积分
- 共 0 条
- 全部回答
-
指尖花凉、已成殇 普通会员 1楼
在事务进行select for update时,如果在等待锁释放时,其他事务使得不再符合where条件,那么可能会发生死锁。死锁是指两个或更多的事务因争夺资源而互相等待,使整个系统无法进行其他操作,从而导致系统无法正常运行。
在SQL中,事务的隔离级别分为读未提交(REPEATABLE-READ)、读已提交(REPEATABLE-READ)、可重复读(REPEATABLE-READ-X)和串行化(SERIALIZABLE)。在事务中,如果在读未提交模式下更新数据,那么就可能会导致死锁。
例如,如果有两个事务T1和T2,它们都想要更新同一张表中的数据,但是它们都等待T2获取锁。在这种情况下,T1就会等待T2释放锁,而T2也不会释放锁,从而导致死锁。在这种情况下,T1需要放弃其对数据库的访问,因为没有其他事务能够获取到锁。
因此,在事务进行select for update时,应尽量避免在等待锁释放时进行其他事务的操作,以避免死锁的发生。
更多回答
网站公告
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部

