您现在的位置是:首页> 编程文章 个人博客模板
关于 Laravel 数据库查询锁必须要知道的知识点
无痕小Q个人博客
2020-02-28 00:21:11【
主页】
1543人已围观
简介关于 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();
阅读量! (1543)
点击排行
退一步海阔天空,这是一种应有的心境。
网站公告
- 欢迎来到我的博客
1:欢迎来到我的博客
2:博客免费api接口现已上线
3:博客会定期更新文章
4:欢迎大家来捧场
站点信息
在你生命的前30年里,你养成习惯。 在你生命的后30年里,你的习惯决定了你。 -- 乔布斯
- 建站时间:2019-8-30
- 网站程序:php,laravel-swoole框架
- 今日流量:288(10分钟统计一次)
- 本月流量:3118
- 浏览总量:461620
- 统计方式:中间件,redis消息队列,定时任务
申请链接友情链接
茅檐低小,溪上青青草。醉里吴音相媚好,白发谁家翁媪。 大儿锄豆溪东,中儿正织鸡笼。最喜小儿亡赖,溪头卧剥莲蓬。