加入收藏 | 设为首页 | 会员中心 | 我要投稿 鹤壁站长网 (https://www.0392zz.cn/)- 分布式云、存储数据、视频终端、媒体处理、内容创作!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

eloquent实现事务的操作是什么?

发布时间:2022-03-21 14:15:59 所属栏目:语言 来源:互联网
导读:事务对于很多新手来说都是比较难理解的内容,为了帮助大家熟悉事务,这篇文章就给大家介绍关于laravel eloquent实现事务的方式,下面我们一起来学习一下吧。 想要在一个数据库事务中运行一连串操作,可以使用DB门面的transaction方法,如果事务闭包中抛出异
       事务对于很多新手来说都是比较难理解的内容,为了帮助大家熟悉事务,这篇文章就给大家介绍关于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 IlluminateSupportFacadesDB;
//开启事务
DB::beginTransaction();
try{
//中间逻辑代码 DB::commit();
}catch (Exception $e) {
//接收异常处理并回滚 DB::rollBack();
}

(编辑:鹤壁站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读