假设两个事务 TA 和 TB,按照下面的顺序来
- TA BEGIN
- TB BEGIN
- TA -> select val from t where id = 1,得到 val 值为 10
- TB -> update t set val = val + 10 where id = 1
- TB COMMIT END
- TA -> select val from t where id = 1,得到 val 值为 10,这个没问题
- TA -> update t set val = val + 10 where id = 1
- TA -> select val from t where id = 1,得到 val 值为 30 而非 20
我加了 10 从 10 变成了 30,说明了本次 TA 事务还是受到了 TB 的影响。这个从现实中来看没什么问题。。但是从 ACID 的 I 上面应该怎么解释呢?
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
https://v2ex.xtra.eu.org/t/789848
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.