PHP 把MYSQL重复ID 二维数组重组为三维数组
应用场景
MYSQL在使用关联查询时,比如 产品表 与 产品图片表关联,一个产品多张产品图片,关联查询结果如下:
$arr=[
['id'=>1,'img'=>'img1'],
['id'=>1,'img'=>'img2'],
['id'=>1,'img'=>'img3'],
['id'=>2,'img'=>'img1'],
['id'=>2,'img'=>'img2'],
['id'=>2,'img'=>'img3'],
['id'=>3,'img'=>'img1'],
['id'=>3,'img'=>'img2'],
['id'=>3,'img'=>'img3'],
]
那么,我们要的结果一般是这样的,如下:
$arr=[
['id'=>1,'img'=>['img1','img2','img3']],
['id'=>2,'img'=>['img1','img2','img3']],
['id'=>3,'img'=>['img1','img2','img3']],
]
解决方案
$arr=[
['id'=>1,'img'=>'img1'],
['id'=>1,'img'=>'img2'],
['id'=>1,'img'=>'img3'],
['id'=>2,'img'=>'img1'],
['id'=>2,'img'=>'img2'],
['id'=>2,'img'=>'img3'],
['id'=>3,'img'=>'img1'],
['id'=>3,'img'=>'img2'],
['id'=>3,'img'=>'img3'],
]
$arr1=array();
foreach ($arr as $key => $value) {
if( in_array($value['id'], $value)){
$arr1[$value['id']]['id']=$value['id'];
$arr1[$value['id']]['img'][]=$value['img'];
}
}
var_dump($arr1);
关键字:php, mysql
版权声明
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处。如若内容有涉嫌抄袭侵权/违法违规/事实不符,请点击 举报 进行投诉反馈!