Answers
可以改用类似Memcached的CAS(Check And Set)冲突检测机制.
http://php.net/manual/zh/memcached.cas.php
获取数据时,获取用户的余额和版本号(表里面有一个版本号字段version):
SELECT balance, version FROM user WHERE id=1 AND balance>10;
更新数据时,更新对应用户ID和获取数据时的版本号的数据.
符合条件,则更新余额,并把版本号+1.
不符合条件,则说明这条数据被更新过,所以本次操作无效.
UPDATE user SET balance=balance-10, version=last_version+1
WHERE id=1 AND version=last_version;
注意到UPDATE里的last_version为SELECT获取的本次操作的版本号.
GG思密达
answered 9 years, 6 months ago