回复内容: rt,数据库什么时候用排它锁,排它锁真的效率低吗,效率低怎么办?
数据修改操作的时候建议上x锁,例如 insert、update 或 delete。确保不会同时同一资源进行多重更新。
效率和安全性毕竟不可兼得,自己取舍啦
可以改用类似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获取的本次操作的版本号.
