eloquent实现事务的操作是什么?
Admin 2021-05-28 群英技术资讯 1153 次浏览
事务对于很多新手来说都是比较难理解的内容,为了帮助大家熟悉事务,这篇文章就给大家介绍关于laravel eloquent实现事务的方式,下面我们一起来学习一下吧。
想要在一个数据库事务中运行一连串操作,可以使用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(); }
关于laravel中eloquent实现事务的方式介绍就到这,上述示例有一定的借鉴价值,有需要的朋友可以参考,希望大家阅读完这篇文章能有所收获。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
学习laravel框架,对于路由的内是需要的掌握的,本文就给大家介绍关于Laravel框架路由设置、路由办法、路由参数等等内容,有这方面学习需要的朋友可以参考参考。
PHP中mcrypt加密实例如下:<?php//当前mcrypt支持的加密模型$modes_list=mcrypt_list_modes();//Array//(//[0]=>cbc//[1]=>cfb//[2]=>ctr//[3]=>ecb//[4]=>ncf
php递增和递减运算符的介绍:1、递增运算符,用++表示递增,++表示在当前变量的值基础上往上加一;2、递减运算符,- - 运算法与 + + 的使用方法类似,在当前变量值得基础上进行减1。
今天小编就为大家分享一篇关于laravel 子查询 & join的使用,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
这篇文章主要为大家介绍了如何利用PHP制作一个通用的Excel导入程序,文中的示例代码讲解详细,感兴趣的小伙伴可以动手尝试一下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008