laravel5 Eloquent 实现事务方式

吾爱主题 阅读:104 2021-09-09 16:11:00 评论:0

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

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

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

手动使用事务

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

?
1 DB::beginTransaction();

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

?
1 DB::rollBack();

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

?
1 DB::commit();

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

2.具体是这样使用的:

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

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

原文链接:https://blog.csdn.net/sanbingyutuoniao123/article/details/54342086

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容