laravel中如何处理多数据库环境下DB::transaction()事务不生效的问题?
- 内容介绍
- 文章标签
- 相关推荐
本文共计397个文字,预计阅读时间需要2分钟。
问题:最近使用Laravel的DB::transaction()方法进行事务操作时,发现事务总体是无效的。代码如下:DB::transaction(function () use ($uid, $roleId) { RoomUserRole::insert(['uid'=> $uid, 'role_id'=> $roleId, 'create_date'=> now()]);});
问题:最近使用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 第二句会报错抛出一个异常, 查看数据库时第一句依然出入成功。
本文共计397个文字,预计阅读时间需要2分钟。
问题:最近使用Laravel的DB::transaction()方法进行事务操作时,发现事务总体是无效的。代码如下:DB::transaction(function () use ($uid, $roleId) { RoomUserRole::insert(['uid'=> $uid, 'role_id'=> $roleId, 'create_date'=> now()]);});
问题:最近使用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 第二句会报错抛出一个异常, 查看数据库时第一句依然出入成功。

