我试图弄清楚如何正确使用/测试 lockforupdate,但我发现它的功能不像我预期的那样
这只是测试
public function index() {
return dd(\DB::transaction(function() {
if (\Auth::guard('user')->check()) {
$model = \App\Models\User::find(1)->lockForUpdate();
sleep(60);
$model->point = 100000;
$model->save();
} else {
$model = \App\Models\User::find(1);
$model->point = 999;
$model->save();
}
return $model;
}));
}
我尝试在 2 个浏览器中进行测试,浏览器 1 用户已登录,浏览器 2 未登录,浏览器 1 点击刷新,然后将锁定更新并在更新前休眠 60 秒
在 60 秒内,我进入浏览器 2 并点击刷新,但记录未锁定,我检查 phpmyadmin 并更新记录(在浏览器 1 的 60 秒锁定触发内)
但60秒后,记录又被浏览器1修改(点100000)
所以我误解了 lockforupdate 的用途?还是我测试不正确?
我期望的是浏览器 2 不应在前 60 秒内修改该行(带有加载图标或错误抛出的空白页面?)
https://laravel.com/docs/5.2/queries#pessimistic-locking
我做了一些研究,但仍然无法理解 sharedLock(LOCK IN SHARE MODE) 和 lockForUpdate(FOR UPDATE) 之间的区别
顺便说一句,我确认数据库是 innodb
原文由 user259752 发布,翻译遵循 CC BY-SA 4.0 许可协议
这项工作,终于,但仍然不明白 sharedLock(LOCK IN SHARE MODE) 和 lockForUpdate(FOR UPDATE) 有什么不同