yii 批量修改方法

yii自带的只有updateAll方法,多条数据某个字段只能修改成统一的。

自写方法:

    /**

     * 批量修改

     * @param $table string 表名

     * @param $key  string 条件主键,作用参考switch中的case

     * @param $val  self 修改主键

     * @param $data array $key与$val主键对应的数据载体

     * @return int 修改成功的条数

     */

    public static function batchUpdate($table, $key, $val, $data)

    {

        $ids = implode(",", array_column($data, $key));

        $condition = " ";

        foreach ($data as $v) {

            $condition .= "WHEN {$v[$key]} THEN '{$v[$val]}' ";

        }

        $sql = "UPDATE {$table} SET {$val} = CASE {$key} {$condition} END WHERE {$key} in ({$ids})";

        $res = Yii::$app->db->createCommand($sql)->execute();

        return $res;

    }

 调用方法及参数:

$infos = [['id' => 1, 'bar_code' => 'ads'], ['id' => 2, 'bar_code' => 'def']];

$this->batchUpdate(TimeResource::tableName(), 'id', 'bar_code', $infos);

 使用含义:通过拼接成多条修改sql,再进行运行。

UPDATE table_name

    SET bar_code=

        CASE id

            WHEN 1 THEN 'val'

            WHEN 2 THEN 'val'

            ELSE

        END

WHERE id IN (1,2);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值