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

我从数据库联查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'],
];
  
萧十郎
浏览 626回答 3
3回答

哈士奇WWW

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

慕勒3428872

题主描述比较乱,不知道我大致这么理解对不对。存在 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)。

一只名叫tom的猫

不想循环嵌套的话,用 array_reduce()
打开App,查看更多内容
随时随地看视频慕课网APP