加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

php – Laravel lockforupdate(悲观锁定)

发布时间:2020-12-14 19:50:53 所属栏目:大数据 来源:网络整理
导读:我正在试图弄清楚如何正确使用/测试lockforupdate,但我发现它的功能不像我的预期 这只是测试 public function index() { return dd(DB::transaction(function() { if (Auth::guard('user')-check()) { $model = AppModelsUser::find(1)-lockForUpdate()
我正在试图弄清楚如何正确使用/测试lockforupdate,但我发现它的功能不像我的预期

这只是测试

public function index() {
        return dd(DB::transaction(function() {
            if (Auth::guard('user')->check()) {
                $model = AppModelsUser::find(1)->lockForUpdate();
                sleep(60);
                $model->point = 100000;
                $model->save();
            } else {
                $model = AppModelsUser::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

这个工作,最后,但仍然不明白什么是sharedLock(LOCK IN SHARE MODE)和lockForUpdate(FOR UPDATE)不同
public function index() {
        return dd(DB::transaction(function() {
            if (Auth::guard('user')->check()) {
                $model = AppModelsUser::lockForUpdate()->find(1);
                sleep(30);
                $model->point = 100000;
                $model->save();
            } else {
                $model = AppModelsUser::lockForUpdate()->find(1);
                $model->point = $model->point + 1;
                $model->save();
            }

            return $model;
        }));
    }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读