laravel 解决多库下的DB::transaction()事务失效问题
时间:2022-07-27
本文章向大家介绍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(); // 指定库,不然都会跑默认配置库的事务
以上这篇laravel 解决多库下的DB::transaction()事务失效问题就是小编分享给大家的全部内容了,希望能给大家一个参考。
- php概述
- php教程
- php环境搭建
- PHP书写格式
- php变量
- php常量
- PHP注释
- php数组
- php字符串 string
- PHP整型 integer
- PHP浮点型 float
- php布尔型
- php数据类型之数组
- php数据类型之对象
- php数据类型之null
- php数据类型之间的转换
- php运算符
- php表达式
- PHP循环控制
- PHP流程控制
- php函数
- php全局变量
- PHP魔术变量
- php命名空间
- php 日期
- PHP包含文件
- php文件
- PHP 文件上传
- php Cookies
- php Sessions
- php email
- php安全email
- php错误处理
- PHP异常处理
- php过滤器
- PHP 高级过滤器
- php json
- php 表单
- PHP MySQL 简介
- PHP 连接 MySQL
- php创建数据库
- php 创建表
- php mysq 插入数据
- PHP MySQL 插入多条数据
- PHP MySQL 预处理语句
- php mysql 读取数据
- php mysql where
- PHP MySQL Order By
- PHP MySQL Update
- PHP MySQL Delete
- php ODBC
- CRC校验原来这么简单
- centos7安装kubernetes教程
- spring-boot自定义starter
- 实操 | kafka如何手动异步提交offset
- 解惑 | 为什么我根据时间戳获得的offset为空呢?
- spring-boot使用aop进行日志记录
- openGauss备机追数Catchup过程中主库写入阻塞问题
- openGauss830版本中对于备份模块的增强与当前问题
- spring boot自动配置原理
- 网站日志分析完整实践
- 聊聊分布式下的WebSocket解决方案
- pod安装、更新库失败,github连接超时问题
- Mysql如何给字符串添加索引(前缀索引)
- Python中5对必知的魔法方法
- java的三种代理