tp3.2 事务

开启事务:M()->startTrans();

提交事务:M()->commit();

回滚事务:M()->rollback();


public function afresh(){
        M()->startTrans();//开启事务
        try{
            $id = I('get.id');//钱包记录id
            $uid = I('uid'); //渠道用户id
            $amount = I('amount'); //原有金额
            $createdAt = I('created_at'); //创建时间
            empty($id)?E('缺少必要参数id'):'';
            empty($uid)?E('缺少必要参数uid'):'';
            empty($amount)?E('缺少必要参数amount'):'';
            empty($createdAt)?E('缺少必要参数createdAt'):'';

            //1.原有金额 $amount
            //2.重新该渠道该天获得当日佣金(收益)
            $agentAmount = $this->getAgentAmount($uid,$createdAt);

            //3.重新算出的佣金更新对应钱包记录金额
            $model = M('cps_wallet_record','cy_');
            $data['amount'] = $agentAmount;
            $model->where(['id'=>$id])->save($data);

            //4.更新用户钱包余额(原钱包余额-当前金额+重新算出的佣金)
            $User = M('cps_user','cy_ct_');
            $oldMoney = $User->where()->getField('money');
            $newMoney = $oldMoney-$amount+$agentAmount;
            $User->where(['id'=>$uid])->save(['money'=>$newMoney]);

            M()->commit();//提交

            $this->return['status'] = 1;
            $this->return['message'] = '重算当日收益成功';

        }catch (\Exception $ex){
            M()->rollback();//回滚
            $this->return['message'] = $ex->getMessage();
        }
        $this->ajaxReturn($this->return);
    }


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值