laravel 解决多库下的DB::transaction()事务失效问题
发布:smiling 来源: PHP粉丝网 添加日期:2022-01-14 15:19:59 浏览: 评论:0
今天小编就为大家分享一篇laravel 解决多库下的DB::transaction()事务失效问题,具有很好的参考价值,希望对大家有所帮助,一起跟随小编过来看看吧。
问题:最近使用laravel的DB::transaction()方法进行事务操作时,发现事务总是无效的,代码如下:
- DB::transaction(function () use ($uid, $roleId) {
- RoomUserRole::insert([
- 'uid' => $uid,
- 'role_id' => $roleId,
- 'created_at' => LARAVEL_START,
- 'updated_at' => LARAVEL_START
- ]);
- RoomUserRoleLog::insert([
- 'uid' => $uid,
- 'handle_type' => 1,
- 'admin_uid' => Auth::user()->id,
- 'created_at' => LARAVEL_START,
- 'updated_at' => LARAVEL_START
- ]);
- });
以上mysql 第二句会报错抛出一个异常, 查看数据库时第一句依然出入成功。查看laravel的DB::transaction()的使用
原因以及解决方法:
项目使用多个数据库配置,DB::transaction()使用的是默认库的事务操作。所以要指定哪个数据库的事务,以上代码调整:
- DB::connection('mysql2')->transaction(function () use ($uid, $roleId) {
- RoomUserRole::insert([
- 'uid' => $uid,
- 'role_id' => $roleId,
- 'created_at' => LARAVEL_START,
- 'updated_at' => LARAVEL_START
- ]);
- RoomUserRoleLog::insert([
- 'uid' => $uid,
- 'handle_type' => 1,
- 'admin_uid' => Auth::user()->id,
- 'created_at' => LARAVEL_START,
- 'updated_at' => LARAVEL_START
- ]);
- }); // 这样你会发现事务才正常回滚
同样
DB::connection('mysql_chat_room')->beginTransaction();
DB::connection('mysql_chat_room')->commit();
DB::connection('mysql_chat_room')->rollBack(); // 指定库,不然都会跑默认配置库的事务
Tags: laravel DB::transaction()
- 上一篇:laravel5 Eloquent 实现事务方式
- 下一篇:最后一页
相关文章
- ·Laravel 5.6中的CURD操作(代码示例详解)(2020-01-15)
- ·如何在laravel 5中创建用于XSS防御的中间件? (2020-01-16)
- ·关于Laravel重定向的七种方法详解(2020-01-26)
- ·如何在laravel 5中使用DB事务?(2020-01-31)
- ·Laravel中如何给图片加水印?(2020-04-05)
- ·Laravel框架数据库CURD操作、连贯操作总结(2021-04-10)
- ·Laravel框架路由配置总结、设置技巧大全(2021-04-10)
- ·Laravel框架中扩展函数、扩展自定义类的方法(2021-04-10)
- ·跟我学Laravel之快速入门(2021-04-16)
- ·跟我学Laravel之安装Laravel(2021-04-16)
- ·跟我学Laravel之配置Laravel(2021-04-16)
- ·跟我学Laravel之请求(Request)的生命周期(2021-04-16)
- ·跟我学Laravel之路由(2021-04-16)
- ·跟我学Laravel之请求与输入(2021-04-17)
- ·跟我学Laravel之视图 & Response(2021-04-17)
- ·laravel安装和配置教程(2021-04-19)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)