laravel按不同条件批量更新不同数据记录一下

本文介绍在 Laravel 中如何高效地进行批量数据更新,避免资源浪费。通过示例展示了一种分组执行的策略,推荐每次更新10-20条记录。
摘要由CSDN通过智能技术生成

laravle按不同条件批量更新不同数据记录一下

laravel中DB类中支持批量插入但是没有批量更新语句
如果当需要批量修改数据时,如果用循环来一条一条更新的话极大的消耗资源
下面为批量更新方法,建议分组执行 一组10-20条记录同时更新

/**
     * 批量更新
     * @param string $whereColumn 条件字段 最好用id主键
     * @param array $rows 批量修改的数据 每一行中必须包含条件列与值 例如 $rows = [['id'=>1,'image'=>'xxx','name'=>'xxx'],['id'=>2,'image'=>'xxx','name'=>'xxx','info'=>'xxxx'],['id'=>3,'其他列1'=>'xxx','其他列2'=>'xxx','其他列3'=>'xxxx']] 每行可修改不同数据
     * @return false|int 成功返回影响行数 失败返回false
     * @throws \Exception
     */
    public function updateBatch(string $whereColumn = 'id', array $rows = [])
    {
   
        if (empty($rows)) {
   
            throw new StatusTagException("data_notfound");
        }
        $tableName = DB::getTablePrefix() . $this->getTable(); // 表名


        // 取出所有需要更新的列
        $updateColumn = [];
        foreach ($rows as $row){
   
            $updateColumn = array_merge($updateColumn,array_keys($row));
        }
        // 去重复
        $updateColumn = array_unique($updateColumn);


        // 拼接sql语句
        $updateSql = "UPDATE " . $tableName . " SET ";
        $sets  = [];
        $bindings = [];
        $isExists = false
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值