laravel队列不超时(在laravel中实现事务回滚的方法)
类别:编程学习 浏览量:1827
时间:2021-10-06 01:52:18 laravel队列不超时
在laravel中实现事务回滚的方法之前做项目用到了事务回滚这个机制。我把代码贴出来多多交流给点意见,我用的是laravel 5.1bane版本的,
|
public static function createDeal( $to_status , $params , $new_balance , $update = true) { \DB::beginTransaction(); try { $update_order_status = \DB::table( 'wallet_order' ) ->where( 'order_id' , $params [ 'order_id' ]) ->update([ 'to_status' => $to_status , 'update_time' => $params [ 'pay_time' ]]); if (! $update_order_status ) { throw new \Exception( "update order error" ); } $create_deal_status = \DB::table( 'wallet_deal' ) ->insert( $params ); if (! $create_deal_status ) { throw new \Exception( "create deal error" ); } if ( $update ) { $update_manage_status = self::updateManage([ 'balance' => $new_balance , 'update_time' => $params [ 'pay_time' ]], $params [ 'from_user' ]); if (! $update_manage_status ) { throw new \Exception( "update manage error" ); } } else { $manage_params = [ 'user_id' => intval ( $params [ 'from_user' ]), 'balance' => $new_balance , 'add_time' => $params [ 'pay_time' ], 'update_time' => $params [ 'pay_time' ], ]; $create_manage_status = self::createManage( $manage_params ); if (! $create_manage_status ) { throw new \Exception( "create manage error" ); } } \DB::commit(); } catch (\Exception $e ) { |
|
//异常处理进行回滚,自己想对应的业务 \DB::rollback(); $trouble_params = [ 'order_id' => $params [ 'order_id' ], 'deal_id' => $params [ 'deal_id' ], 'from_user' => $params [ 'from_user' ], 'to_user' => $params [ 'to_user' ], 'total_amount' => $params [ 'total_amount' ], 'add_time' => $params [ 'pay_time' ], 'type' => $params [ 'type' ], 'to_status' => $to_status ]; \DB::connection( 'mongodb' ) ->table( 'wallet_trouble' ) ->insert( $trouble_params ); } finally { self::createLog( $params , $to_status ); } } |
以上这篇在laravel中实现事务回滚的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持开心学习网。
原文链接:https://blog.csdn.net/chen529834149/article/details/77161485
您可能感兴趣
- sql提交事务代码(SQL SERVER提交事务回滚机制)
- jenkins回滚docker容器(关于docker部署的jenkins跑git上的程序的问题)
- laravel队列不超时(在laravel中实现事务回滚的方法)
- sql server事务回滚(SQL Server 添加Delete操作回滚日志方式)
- 阿里云ecs所有文件备份到本地(阿里云ECS服务器的系统重装、快照备份、恢复数据回滚教程)
- 休闲VS新古典 办公家居简约设计(办公家居简约设计)
- 15个新成 园 位置公布 深圳龙岗2022年共建花园建设又有大动作(15个新成园位置公布)
- 记者手记 书记带我去 巡街(记者手记书记带我去)
- 富士胶片集团将向土耳其东南部地震灾民捐赠5000万日元 | 美通社(富士胶片集团将向土耳其东南部地震灾民捐赠5000万日元)
- 二次创业 的富士胶片,在进博会上首次展示完成转型后的全线医疗产品(二次创业的富士胶片)
- 富士胶片 中国 我们对上海的信心没有任何改变(富士胶片中国)
热门推荐
- mysql实用教程(Mysql调优Explain工具详解及实战演练推荐)
- python爬虫爬取网页信息教程(python爬虫爬取微博评论案例详解)
- dede联动菜单样式(dede添加自定义属性完美解决方案)
- dedecms 图片不显示(解析织梦DedeCMS图片按月存放的实现方法)
- python编程ai人工智能(AI领域都在用Python即将被淘汰?网友预测未来的编程语言不会是TA)
- phpmysql怎么搭建(PHP使用PDO、mysqli扩展实现与数据库交互操作详解)
- innodb运行内存(详细了解 InnoDB 内存结构及其原理)
- python 文本分析 摘要(用Python逐行分析文件方法)
- C#插入排序
- django数据库详解(Django页面数据的缓存与使用的具体方法)