为了账号安全,请及时绑定邮箱和手机立即绑定

怎样用原生函数将二维数组中满足条件的子数组提取出来

怎样用原生函数将二维数组中满足条件的子数组提取出来

PHP
萧十郎 2019-03-14 01:03:19
我从数据库联查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 回答

?
哈士奇WWW

TA贡献1799条经验 获得超6个赞

php很多数组原生函数的函数原型也是对数组循环处理,除非你的数组极其庞大复杂,否则foreach不会出现什么效率问题

查看完整回答
反对 回复 2019-03-18
?
慕勒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)。

查看完整回答
反对 回复 2019-03-18
?
一只名叫tom的猫

TA贡献1906条经验 获得超2个赞

不想循环嵌套的话,用 array_reduce()

查看完整回答
反对 回复 2019-03-18
  • 3 回答
  • 0 关注
  • 609 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信