当前位置:  开发笔记 > 编程语言 > 正文

Laravel lockforupdate(悲观锁定)

如何解决《Laravellockforupdate(悲观锁定)》经验,为你挑选了1个好方法。

我正在试图弄清楚如何正确使用/测试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用于?或者我测试不正确?

我期望的是在前60秒内浏览器2不应该修改行(带有加载图标的空白页或错误抛出?)

https://laravel.com/docs/5.2/queries#pessimistic-locking

我做了一些研究,但仍然无法理解sharedLock(LOCK IN SHARE MODE)和lockForUpdate(FOR UPDATE)之间的区别

顺便说一句,我确认数据库是innodb



1> user259752..:

这个工作,最后,但仍然不明白什么是sharedLock(LOCK IN SHARE MODE)和lockForUpdate(FOR UPDATE)不同

    public function index() {
        return dd(\DB::transaction(function() {
            if (\Auth::guard('user')->check()) {
                $model = \App\Models\User::lockForUpdate()->find(1);
                sleep(30);
                $model->point = 100000;
                $model->save();
            } else {
                $model = \App\Models\User::lockForUpdate()->find(1);
                $model->point = $model->point + 1;
                $model->save();
            }

            return $model;
        }));
    }


从文档:https://laravel.com/docs/5.2/queries#pessimistic-locking sharedLock lock仅用于写入,lockForUpdate也阻止它们被选中
推荐阅读
路人甲
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有