laravel mysql 锁表_使用 Laravel sharedLock 与 lockForUpdate 进行数据表行锁
场景
拼团功能,当 A 客户开团之后(两人团),如果 B 和 C 同时支付,如何规避两人同时将拼团人数增加。
Laravel 中 sharedLock 与 lockForUpdate 的区别
sharedLock 对应的是 LOCK IN SHARE MODE
lockForUpdate 对应的是 FOR UPDATE
sharedLock 与 lockForUpdate 相同的地方是,都能避免同一行数据被其他 transaction 进行 update。
不同的地方是:
sharedLock 不会阻止其他 transaction 读取同一行
lockForUpdate 会阻止其他 transaction 读取同一行 (需要特别注意的是,普通的非锁定读取读取依然可以读取到该行,只有 sharedLock 和 lockForUpdate 的读取会被阻止。)
即 sharedLock locks only for write, lockForUpdate also prevents them from being selected
这样做是有意义的,例如,两个 transaction 要更新同一个计数器,如果不使用 lockForUpdate,
会导致两个 transaction 同时读到同一个初始值,然后在应用层逻辑中增加计数之后,提交到数据库中,后者的操作会覆盖掉前者的操作。
如何测试
在 MySQL 命令行终端操作一个表
mysql> begin;
Query OK, 0 rows affected (0.00 sec)
mysql> select * from users for update;
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
