php - 数据库什么时候用排它锁,排它锁真的效率低吗,效率低怎么办?
ringa_lee
ringa_lee 2017-04-10 15:50:07
[PHP讨论组]

RT,数据库什么时候用排它锁,排它锁真的效率低吗,效率低怎么办?

ringa_lee
ringa_lee

ringa_lee

全部回复(2)
大家讲道理

数据修改操作的时候建议上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获取的本次操作的版本号.

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号