laravel5 Eloquent 实现事务方式

Iris ·
更新时间:2024-09-20
· 967 次阅读

1.官方手册是这样介绍的:

想要在一个数据库事务中运行一连串操作,可以使用DB门面的transaction方法,如果事务闭包中抛出异常,事务将会自动回滚。如果闭包执行成功,事务将会自动提交。使用transaction方法时不需要担心手动回滚或提交:

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

手动使用事务

如果你想要手动开始事务从而对回滚和提交有一个完整的控制,可以使用DB门面的beginTransaction方法:

DB::beginTransaction();

你可以通过rollBack方法回滚事务:

DB::rollBack();

最后,你可以通过commit方法提交事务:

DB::commit();

注意:使用DB门面的事务方法还可以用于控制查询构建器和 Eloquent ORM 的事务。

2.具体是这样使用的:

use Illuminate\Support\Facades\DB; //开启事务 DB::beginTransaction(); try{ //中间逻辑代码 DB::commit(); }catch (\Exception $e) { //接收异常处理并回滚 DB::rollBack(); }

以上这篇laravel5 Eloquent 实现事务方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持软件开发网。

您可能感兴趣的文章:在laravel中实现事务回滚的方法laravel Model 执行事务的实现laravel 解决多库下的DB::transaction()事务失效问题



laravel 事务

需要 登录 后方可回复, 如果你还没有账号请 注册新账号