php更新mysql大量数据_php mysql 批量更新数据

使用原生 sql 批量更新用户积分数据

订单列表中查出 $list,包含  buy_id , total_money 字段    $list = [

0 => ['buyer_id' => 1,'total_money' => 20],

1 => ['buyer_id' => 4,'total_money' => 77],

2 => ['buyer_id' => 7,'total_money' => 50],

3 => ['buyer_id' => 10,'total_money' => 15],

4 => ['buyer_id' => 21,'total_money' => 22],

5 => ['buyer_id' => 17,'total_money' => 120],

];

组合UPDATE语句,其中 `bp` 为用户表积分字段

$ids = '';

$sql = 'UPDATE user SET bp = CASE id ';

$sql = '';

foreach ( $list as $key => $value) {

$sql .= sprintf("WHEN %d THEN `bp` + %d ", $value['buyer_id'], $value['total_money']);

$ids .= $value['buyer_id'].',';

}

$ids = rtrim($ids,',');

$sql .= "END WHERE id IN ($ids)";

实际执行的sqlUPDATE user SET bp = CASE id WHEN 1 THEN `bp` + 20 WHEN 4 THEN `bp` + 77 WHEN 7 THEN `bp` + 50 WHEN 10 THEN `bp` + 15 WHEN 21 THEN `bp` + 22 WHEN 17 THEN `bp` + 120 END WHERE id IN (1,4,7,10,21,17)执行sql ==== 搞定

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值