我从数据库联查a表和b表查询出来一个二维数组,a表与b表是一对多的关系,查出来的数据a表会有重复,我现在希望将数据中满足条件的子数组提取出来,条件可以是数据中相同a表id。
主要是不希望用循环,因为我还有别的逻辑要处理,循环嵌套下来效率太低了!
ab表联查出来数据类似下面的结构:
$array=[
['id'=>1,'name'=>'name1','value'=>'value1'],
['id'=>1,'name'=>'name2','value'=>'value2'],
['id'=>2,'name'=>'name3','value'=>'value3'],
['id'=>3,'name'=>'name4','value'=>'value4'],
['id'=>3,'name'=>'name5','value'=>'value5'],
.......
];
里面的id其实是a表的数据,是有可能重复的,我的目标就是将id==1的两条数据从上面的大数组里给弄出来搞个小数组单独装起来,最终想要的结果如下:
$end=[
['id'=>1,'name'=>'name1','value'=>'value1'],
['id'=>1,'name'=>'name2','value'=>'value2'],
];
3 回答
慕勒3428872
TA贡献1848条经验 获得超6个赞
题主描述比较乱,不知道我大致这么理解对不对。
存在 a 和 b 两个数组,数组结构如下:
$a = [['id' => '1', 'name' => 'name1'],['id' => '2', 'name' => 'name2']];
$b = [['id' => '1', 'value' => 'value1'],['id' => '2', 'value' => 'value2']];
然后目标是得到是将数组 b 中的部分数据加入到数组 a 中,得到一种类似于这样的数据:
$c = [['id' => '1','name' => 'name1' ,'value' => 'value1'],['id' => '2','name' => 'name2', 'value' => 'value2']];
这种情况,如果两个数组都比较大,比如说都有 10000 组数据左右,直接二重循环确实会出现性能问题。
这种问题可以通过将其中一个数组根据 id 设置成 key-value 的形式来提高性能,代码如下:
$storage_a = [];
foreach($a as $value) {
$storage_a[$value['id']] = $value;
}
foreach($b as $value) {
if(isset($storage_a[$value['id']])) {
$storage_a[$value['id']]['value'] = $value['value'];
}
}
print_r($storage_a);
具体 PHP 的原生函数有没有实现类似的功能,题主可以去 PHP 手册查一下。
因为题主说是一对多的内容,所以代码需要根据实际情况做一下调整。
从性能上来看,直接二重循环的复杂度是 O(n*m),这样写的复杂度可以大致认为是 O(n+m)。
- 3 回答
- 0 关注
- 625 浏览
添加回答
举报
0/150
提交
取消