您现在的位置是:首页> 编程文章 个人博客模板

关于 Laravel 数据库查询锁必须要知道的知识点

无痕小Q个人博客 2020-02-28 00:21:11主页 1586人已围观

简介关于 Laravel 数据库查询锁必须要知道的知识点

Mysql 锁的类型


1 共享锁

* 查询数据 会阻塞 等待没有任何人占用的时候再返回

* 更新数据 会阻塞 等待没有任何人占用的时候再返回


DB::table('users')->where('id', 100)->lockForUpdate()->first();

2 悲观锁

* 查询数据 正常查询返回

* 更新数据 会阻塞 等待上一个锁更新执行完毕后再更新


DB::table('users')->where('id', 100)->sharedLock()->first();

如果我直接使用锁不使用事务能正常逻辑吗?


正确

DB::transaction(function() {

  $user = DB::table('users')->where('id', 100)->lockForUpdate()->first();

  $user->nick_name = "老王";

  $user->save();

});

错误

$user = DB::table('users')->where('id', 100)->lockForUpdate()->first();

$user->nick_name = "老王";

$user->save();

阅读量! (1586)

关于本站

昵称:无痕小Q

职业:php-go-web开发工程师

现居:北京

Email:1838638884@qq.com

    戍鼓断人行,秋边一雁声。  露从今夜白,月是故乡明。  有弟皆分散,无家问死生。  寄书长不达,况乃未休兵。

网站公告

  • 欢迎来到我的博客

  • 1:欢迎来到我的博客


    2:博客免费api接口现已上线


    3:博客会定期更新文章


    4:欢迎大家来捧场


    洞角丹砂吐锦云,龟毛铅彩瑞氤氲。 我来收入县胎鼎,炼到洪蒙未剖分。

站点信息

世间无常, 你是人间琳琅. 最常见的勇气就是在日常生活中做到诚实和正直,能够抵制诱惑,敢于讲真话,表现自我真实的一面,而不好虚伪造作。
  • 建站时间:2019-8-30
  • 网站程序:php,laravel-swoole框架
  • 今日流量:127(10分钟统计一次)
  • 本月流量:21047
  • 浏览总量:488487
  • 统计方式:中间件,redis消息队列,定时任务
    生活飞快地并非我一人。朱自清先生曾咏叹过时光匆匆:洗手的时候,日子从水盆里过去;吃饭的时候,日子从饭碗里过去;默默时,便从凝然的双眼前过去。