Maison > développement back-end > tutoriel php > 数据库什么时候用排它锁,排它锁真的效率低吗,效率低怎么办?

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

WBOY
Libérer: 2016-06-06 20:31:12
original
1172 Les gens l'ont consulté

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

回复内容:

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

数据修改操作的时候建议上X锁,例如 INSERT、UPDATE 或 DELETE。确保不会同时同一资源进行多重更新。
效率和安全性毕竟不可兼得,自己取舍啦

可以改用类似Memcached的CAS(Check And Set)冲突检测机制.
http://php.net/manual/zh/memcached.cas.php

获取数据时,获取用户的余额和版本号(表里面有一个版本号字段version):

<code>SELECT balance, version FROM user WHERE id=1 AND balance>10;
</code>
Copier après la connexion

更新数据时,更新对应用户ID和获取数据时的版本号的数据.
符合条件,则更新余额,并把版本号+1.
不符合条件,则说明这条数据被更新过,所以本次操作无效.

<code>UPDATE user SET balance=balance-10, version=last_version+1 
WHERE id=1 AND version=last_version;
</code>
Copier après la connexion

注意到UPDATE里的last_version为SELECT获取的本次操作的版本号.

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal