经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » PHP » 查看文章
在laravel中实现事务回滚的方法
来源:jb51  时间:2019/10/11 8:37:01  对本文有异议

之前做项目用到了事务回滚这个机制。我把代码贴出来多多交流给点意见,我用的是laravel 5.1bane版本的,

  1. public static function createDeal($to_status, $params, $new_balance, $update = true)
  2. {
  3. \DB::beginTransaction();
  4. try {
  5. $update_order_status = \DB::table('wallet_order')
  6. ->where('order_id', $params['order_id'])
  7. ->update(['to_status' => $to_status, 'update_time' => $params['pay_time']]);
  8. if (!$update_order_status) {
  9. throw new \Exception("update order error");
  10. }
  11. $create_deal_status = \DB::table('wallet_deal')
  12. ->insert($params);
  13. if (!$create_deal_status) {
  14. throw new \Exception("create deal error");
  15. }
  16. if ($update) {
  17. $update_manage_status = self::updateManage(['balance' => $new_balance, 'update_time' => $params['pay_time']], $params['from_user']);
  18. if (!$update_manage_status) {
  19. throw new \Exception("update manage error");
  20. }
  21. } else {
  22. $manage_params = [
  23. 'user_id' => intval($params['from_user']),
  24. 'balance' => $new_balance,
  25. 'add_time' => $params['pay_time'],
  26. 'update_time' => $params['pay_time'],
  27. ];
  28. $create_manage_status = self::createManage($manage_params);
  29. if (!$create_manage_status) {
  30. throw new \Exception("create manage error");
  31. }
  32. }
  33. \DB::commit();
  34. } catch (\Exception $e) {
  1. //异常处理进行回滚,自己想对应的业务
  2. \DB::rollback();
  3. $trouble_params = [
  4. 'order_id' => $params['order_id'],
  5. 'deal_id' => $params['deal_id'],
  6. 'from_user' => $params['from_user'],
  7. 'to_user' => $params['to_user'],
  8. 'total_amount' => $params['total_amount'],
  9. 'add_time' => $params['pay_time'],
  10. 'type' => $params['type'],
  11. 'to_status' => $to_status
  12. ];
  13. \DB::connection('mongodb')
  14. ->table('wallet_trouble')
  15. ->insert($trouble_params);
  16. } finally {
  17. self::createLog($params, $to_status);
  18. }
  19. }

以上这篇在laravel中实现事务回滚的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号