如何在php/lavel中从二维数组中获取一维数组


How to get single dimensional array from two dimensional array in php/laravel?

我正在做laravel项目。我有一个sql查询,

$catcount=2;
    for($i=0;$i<$catcount;$i++) {
        $subCat[] = Category::where('parent_id', '=', $userCategory[$i])->pluck('id');
    }

$subCat将数组返回为,

[[54,55,56,57,58],[48,49,50,51,52]]

我想把这个数组作为一个一维数组,比如

[54,55,56,57,58,48,49,50,51,52]

我不知道如何做到这一点,请提前帮助和感谢。

我建议您在查询之前进行id合并,这样只访问一次数据库将节省一些运行时间。

    $catcount    = 2;
    $parents_ids = [];
    for ($i = 0; $i < $catcount; $i++) {
        $parents_ids[] = $userCategory[$i];
    }
    $subCats = Category::whereIn('parent_id', $parents_ids)->pluck('id');
$catcount=2;
for($i=0;$i<$catcount;$i++) {
   $subCat[] = Category::where('parent_id', '=' $userCategory[$i])->pluck('id');
}
array_merge($subCat[0],$subCat[1]);

从您的最终数组中,您只需执行数组合并

list($a1, $a2) = $subCat;
$subCat = array_merge($a1, $a2);

有很多方法可以做到这一点。其中之一:简单,但通用,可读且可更新(如果数据结构发生变化,您可以很快更新此代码):

$newArr = [];
foreach ($subCat as $subArr) {
    foreach ($subArr as $value) {
        $newArr[] = $value;
    }
}

如果您的数组有多个元素,您可以使用以下代码合并它们:

$subCats = call_user_func_array("array_merge", $subCat);