想要在一个数据库事务中运行一连串操作,可以使用DB门面的transaction方法,如果事务闭包中抛出异常,事务将会自动回滚。如果闭包执行成功,事务将会自动提交。使用transaction方法时不需要担心手动回滚或提交
transaction 方法还要第二个参数可供指定——当死锁发生时,事务最大的尝试次数。一旦超过这个指定次数,就会抛出异常
DB::transaction(function () {
DB::table('users')->update(['votes' => 1]);
DB::table('posts')->delete();
}, 5);
模式一:自动提交事务
DB::transaction(function () {
DB::table('users')->update(['votes' => 1]);
DB::table('posts')->delete();
//要执行的sql语句
});
模式二:手动提交事务
如果你想要手动开始事务从而对回滚和提交有一个完整的控制,可以使用DB门面的beginTransaction方法
DB::beginTransaction();//开启一个事务
DB::rollBack();//回滚事务
DB::commit();//提交事务
提示:使用DB门面的事务方法还可以用于控制查询构建器和 Eloquent ORM 的事务
使用try catch 处理事务的异常处理
DB::beginTransaction();
try{ //中间逻辑代码
DB::commit();
}catch (\Exception $e) {
//接收异常处理并回滚
DB::rollBack();
}