假设id=1001有1000块钱,张三李四同时取钱。如下:
P_Account
Id money version
1001 1000 0
张三查询余额1000,此时版本号是0。取了200,还剩800,提交之后此时版本号是1
Zhangsan
Id money version
1001 1000 0
1001 1000-200=800 1
李四和张三同时查询查询余额1000,此时版本号是0。取了300,理应还剩700,此时提交事务,发现版本号变为了1(因为张三提交事务改变了版本号)
李四提交时,比较版本的值是否一致
如果一致允许提交,否则不允许提交(版本号由0变成1,不允许提交了)
lisi
Id money version
1001 1000 0
1001 1000-300=700 0
1001 800 1
1001 800-300=500 2