Laravel lockforupdate (Pessimistic Locking)
我试图弄清楚如何正确使用/测试锁定更新,但我发现功能不像我预期的那样
这只是测试
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)再次修改
所以我误解了锁的更新是用来的?或者我测试得不正确?
我所期望的是,浏览器2不应该在前60秒内修改该行(带有加载图标或错误抛出的空白页?
https://laravel.com/docs/5.2/queries#pessimistic-locking
我做了一些研究,但仍然无法理解sharelock(锁定在共享模式下)和lockForUpdate(用于更新)之间的区别
顺便说一句,我确认数据库是innodb