laravel数据库事务回滚

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了laravel数据库事务回滚相关的知识,希望对你有一定的参考价值。

       背景:近期使用Laravel-5.4进行项目开发时涉及到关联模型的数据操作,想到用事务回滚。中间涉及到数据引用及异常的捕获。

        数据库事务回滚有两种方式:自动回滚、手动回滚。

举例如下:

        自动回滚

    function(Request $request){      
    DB::transaction(function () use ($request) {
         try {
           $admin = Admin::create([‘name‘ => $request->name, ‘password‘ => encrypt($request->password), ‘email‘ => $request->email]);
         $admin->roles()->attach($request->role_id);
         //    $admin->roles()->attach(‘sd‘);//故意输入错误参数类型,commit失败
         return ‘success‘;
       } catch (\Exception $exception) {
         return $exception->getMessage();
       }
        });
    }

              需要使用use 引用请求数据$request。否则报错 "Undefined variable:request"


        手动回滚

    function(Request $request){
        DB::beginTransaction();
        try {
            $admin = Admin::create([‘name‘ => $request->name, ‘password‘ => encrypt($request->password), ‘email‘ => $request->email]);
            $admin->roles()->attach($request->role_id);        
            DB::commit();
            return ‘success‘;
        } catch (\Exception $exception) {
            DB::rollBack();
            return $exception->getMessage();
        }
    }


以上是关于laravel数据库事务回滚的主要内容,如果未能解决你的问题,请参考以下文章

Laravel 4.2 - 多个数据库的事务回滚问题

Laravel 测试不会在每次测试后回滚事务

laravel 中事务的使用

Laravel DB::transaction 不回滚异常

Laravel之事务与锁

laravel 嵌套事务