常用PHP数组两层循环优化

我们经常都会有这样的需求,两个数组中某个字段关联,根据这个字段合并为一个数组,如下例子:

// 数组a的id  与 数组b的pid 关联
$a = [['id'=>1,'name'=>'a1'],['id'=>2,'name'=>'a2'],['id'=>3,'name'=>'a3']];
$b = [['pid'=>1,'money'=>100],['pid'=>2,'money'=>200],['pid'=>3,'money'=>'300']];


// 假设我们需要得到最后的列表结果为
// [['id'=>1,'name'=>'a1','money'=>100],['id'=>2,'name'=>'a2','money'=>100],['id'=>3,'name'=>'a3','money'=>100]];
// 普通写法
foreach($a as $k1 => $v1){
    foreach($b as $k2 => $v2){
        if($v1['id'] == $v2['pid']){
            $a[$k]['money'] = $v2['money']
        }
    }
}
return $a;    //最终$a为我们需要的数据



// 优化写法--重组数组b,将pid值设为健,money设为值,一一对应
$newArr = array_column($b,'money','pid'); //1参数为值,2参数为键
foreach($a as $k1 => $v1){
   $a[$k1]['money'] = $newArr[$v1['id']];
}
return $a

优化后明显数组b只需被循环一次,而优化前数组b需要循环count($a) 次,当数据多时性能还是有很大差异的;

你可能感兴趣的:(PHP)