开发者社区 > 云原生 > 中间件 > 正文

全局锁是在执行到某个 sql 的时候才会把目标数据添加进全局锁。这种情况的结果是这样吗?:

全局锁是在执行到某个 sql 的时候才会把目标数据添加进全局锁吧。 如果业务A和业务B 同时执行 1、业务A锁住了数据1,业务B锁住了数据2 2、业务A需要操作数据2,业务B需要操作数据1

这种情况的结果是这样吗?: 业务A获取数据2的锁失败回滚并释放全局锁 业务B获取数据1的锁失败回滚并释放全局锁

展开
收起
fuxixi 2022-09-26 16:47:29 601 0
1 条回答
写回答
取消 提交回答
  • 你说的是死锁,这个at没有死锁检测,会出现这种情况,但是假设a锁住1,竞争2的最大时间为300ms,b锁住2竞争1最大时间为200ms,那么业务a是可以通过的,b是不行的。

    2022-09-26 17:21:27
    赞同 展开评论 打赏
问答分类:
SQL
问答地址:

为企业提供高效、稳定、易扩展的中间件产品。

相关电子书

更多
SQL Server 2017 立即下载
GeoMesa on Spark SQL 立即下载
原生SQL on Hadoop引擎- Apache HAWQ 2.x最新技术解密malili 立即下载