我正在做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);