当前位置:首页 > CMS教程 > 其它CMS > 列表

laravel5 Eloquent 实现事务方式

发布:smiling 来源: PHP粉丝网  添加日期:2022-01-14 15:15:43 浏览: 评论:0 

今天小编就为大家分享一篇laravel5 Eloquent 实现事务方式,具有很好的参考价值,希望对大家有所帮助,一起跟随小编过来看看吧。

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

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

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

手动使用事务

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

DB::beginTransaction();

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

DB::rollBack();

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

DB::commit();

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

2.具体是这样使用的:

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

Tags: laravel5事务方式 Eloquent

分享到: