laravel中如何处理多数据库环境下DB::transaction()事务不生效的问题?

2026-05-22 16:181阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计397个文字,预计阅读时间需要2分钟。

laravel中如何处理多数据库环境下DB::transaction()事务不生效的问题?

问题:最近使用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()事务不生效的问题?

问题:最近使用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 第二句会报错抛出一个异常, 查看数据库时第一句依然出入成功。

阅读全文