400 0867 457

NEWS/新闻

分享你我感悟

您当前位置> 主页 > 新闻 > 技术开发

Laravel中怎么进行数据库事务处理

发表时间:2025-11-17 00:00:00

文章作者:穿越時空

浏览次数:

Laravel通过DB::transaction()确保数据库操作的原子性,闭包内操作成功则自动提交,异常则回滚;支持手动事务控制及自定义重试次数,默认死锁时重试5次,保障数据一致性。

在 Laravel 中进行数据库事务处理,主要是为了确保一组数据库操作要么全部成功,要么全部失败,从而保持数据的一致性。Laravel 基于 PDO 的事务功能,提供了简单直观的 API 来管理事务。

使用 DB::transaction() 方法

最常用的方式是使用 DB::transaction() 方法。Laravel 会自动处理提交和回滚,你只需要把需要执行的逻辑放在闭包中。

示例: ```php use Illuminate\Support\Facades\DB;

DB::transaction(function () { DB::table('users')->update(['votes' => 1]);

DB::table('posts')->delete();

});

如果闭包中的代码成功执行,事务会自动提交。如果抛出异常(比如数据库错误或手动 throw),Laravel 会自动回滚事务。

手动控制事务

如果你需要更精细的控制,可以手动调用 DB::beginTransaction()DB::commit()DB::rollback()

示例: ```php use Illuminate\Support\Facades\DB; DB::beginTransaction(); try { DB::table('users')->update(['votes' => 1]); DB::table('posts')->delete(); DB::commit(); } catch (\Exception $e) { DB::rollback(); // 处理异常 throw $e; }

这种方式适合在捕获特定异常后执行额外逻辑,比如记录日志。

事务中的死锁与重试

Laravel 的 DB::transaction() 默认会在发生死锁或超时的情况下自动重试最多 5 次。你可以通过传入第二个参数来自定义重试次数。

```php DB::transaction(function () { // 业务逻辑 }, 3); // 最多重试 3 次 ```

注意:重试机制只适用于闭包内抛出的 QueryException 类型异常。

基本上就这些。只要合理使用事务,就能有效避免数据不一致的问题,特别是在处理订单、余额变动等关键业务时尤为重要。

相关案例查看更多