V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
awanganddong
V2EX  ›  PHP

mysql update 更新失败的原因。

  •  
  •   awanganddong · 2 天前 · 745 次点击

    后台有一个批量操作的功能。

    用户审核通过,然后给他的邀请人加优惠价。

    伪代码
    foreach(users as user){
        //通过审核(事务保证)
        
       // 给邀请人加优惠卷(事务保证)
    }
    

    现在出现的问题是用户加优惠价这个过程,对用户信息更新优惠卷总数失败。

    给用户加优惠卷有 2 个插入操作,一个更新操作。

    刚才进行批量操作,执行了 20 个用户,其中几个 update 操作失败。所以对这个问题没想明白,mysql rr 级别。

    6 条回复    2025-01-15 22:52:39 +08:00
    evan1
        1
    evan1  
       2 天前 via iPhone
    看看日志
    loveyu
        2
    loveyu  
       2 天前 via Android
    假设不是 orm ,循环生成好 SQL ,然后一个 begin exec end 搞定。
    如果是 orm ,插入后还要读取数据,用事务中的数据数据做一堆操作。先加个分布式锁,然后循环内部 开始事务 干活 提交
    xiaofan2
        3
    xiaofan2  
       2 天前
    你校验了 update 的返回值吗?
    awanganddong
        4
    awanganddong  
    OP
       2 天前
    @xiaofan2 没有校验 update 返回值。做的类似这样的操作
    Db::transaction(function () {

    //用户账号
    $money = 10000;
    $accountModel = new Account();
    $accountModel->where('uid', 0)
    ->update([
    'dream_fund' => $money,
    ]);

    $billData = [
    'uid' => 0,
    'money' => 0,
    'itime' => time(),
    'utime' => time(),
    ];
    $this->model->data($billData);
    $this->model->save();
    });
    suifengba
        5
    suifengba  
       2 天前
    失败报错什么
    awanganddong
        6
    awanganddong  
    OP
       2 天前
    找到问题了,我在中途有个其他 update 操作,把用户余额还原了。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2699 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 21ms · UTC 05:13 · PVG 13:13 · LAX 21:13 · JFK 00:13
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.