laravel5批量更新函数

updateBatch

主要用于批量更新不同id的不同属性
自带的update仅支持更新相同属性内容
例如:文章列表的排序更新

第二个参数为表名
配合model方法Article::getabname()

public static function getabname()
{
        return env('DB_PRE').with(new static)->getTable();
}
/*
 * ----------------------------------
 * update batch 
 * ----------------------------------
 * multiple update in one query
 *
 * multipleData ( required | array of array )
 * tablename( required | string )
 */
function updateBatch($multipleData = array(), $tableName = "articles"){

    if( $tableName && !empty($multipleData) ) {
        // column or fields to update
        $updateColumn = array_keys($multipleData[0]);
        $referenceColumn = $updateColumn[0]; //e.g id
        unset($updateColumn[0]);
        $whereIn = "";

        $q = "UPDATE `".$tableName."` SET `"; 
        foreach ( $updateColumn as $uColumn ) {
            $q .=  $uColumn."` = CASE ";

            foreach( $multipleData as $data ) {
                $q .= "WHEN ".$referenceColumn." = ".$data[$referenceColumn]." THEN '".$data[$uColumn]."' ";
            }
            $q .= "ELSE `".$uColumn."` END, ";
        }
        foreach( $multipleData as $data ) {
            $whereIn .= "'".$data[$referenceColumn]."', ";
        }
        $q = rtrim($q, ", ")." WHERE ".$referenceColumn." IN (".  rtrim($whereIn, ', ').")";

        // Update  
        return \DB::update(DB::raw($q));

    } else {
        return false;
    }
}

使用方法

    $ids = $request->id;
    if(!count($ids))
    return redirect()->back()->withErorr('没有需要更新的数据!');
    $orders = $request->order;
    foreach ($ids as $key => $value) {
        $update[]=['id'=>$value,'order'=>$orders[$key]];
    }
    $ok = updateBatch($update,Article::getabname());
    if($ok){
        return redirect()->back()->withMessage('移动成功!');
    }else{
        return redirect()->back()->withErorr('更新失败!');
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,138评论 25 709
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,180评论 19 139
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 11,262评论 6 13
  • 人生的道路远大而无尽头,但是每一个人总是越走越远,人生就像一只飞翔的鸟儿,总爱往上飞,而不是往下掉。而人生的道路更...
    解晓萍阅读 268评论 0 1
  • 五月石竹香/徐宏 谨于此诗献给天下所有母亲: 五月石竹香-----为母亲节而作 徐 宏 盛满温馨的五月...
    sunxuhong阅读 594评论 1 2