Laravel DB事务怎么使用_Laravel数据库事务回滚操作

admin 百科 16
使用DB::transaction()可确保数据库操作原子性,如余额扣减与记录写入同时成功或回滚;支持手动事务控制,适用于复杂逻辑;需避免耗时操作、合理使用行锁,并注意事务生命周期与队列重试问题。

Laravel DB事务怎么使用_Laravel数据库事务回滚操作-第1张图片-佛山资讯网

在 Laravel 中使用数据库事务可以确保一组数据库操作要么全部成功,要么全部失败回滚,从而保证数据的一致性。特别是在处理多表写入、更新或删除等关键业务逻辑时,事务非常有用。

1. 使用 DB::transaction() 开启事务

最常见的方式是使用 DB::transaction() 方法包裹需要原子执行的代码块。如果代码块内抛出异常,Laravel 会自动触发回滚;如果没有异常,则自动提交事务。

use Illuminate\Support\Facades\DB;

DB::transaction(function () {
    $user = DB::table('users')->where('id', 1)->lockForUpdate()->first();

    if ($user->balance         throw new \Exception('余额不足');
    }

    DB::table('users')->where('id', 1)->decrement('balance', 50);
    DB::table('transactions')->insert([
        'user_id' => 1,
        'amount' => -50,
        'created_at' => now(),
        'updated_at' => now()
    ]);
});

上面的例子中,如果余额不足抛出异常,两个数据库操作都会被回滚。

2. 手动控制事务(begin、commit、rollback)

你也可以手动开启事务,适用于更复杂的控制逻辑。

标签: laravel cad

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~