list和tag都是数据库里的数据,想要用mysql这样的查询语句查询出来,得到下面的查询结果,在不用foreach这样的php循环语句下得到结果
list => array( array(id => 1, title => '这是title'), array(id => 2, title => '这是title2'),)//list_id和list里的id关联tag => array( array(id => 1, list_id = 1, name => 'tag1'), array(id => 2, list_id = 1, name => 'tag2'), array(id => 3, list_id = 2, name => 'tag3'), );
这样的,该怎样查出
select => array(array( id => 1, title => '这是title', tag =>array( array( id =1, name => 'tag1'), array(id=2,name='tag2') ),),array( id => 2, title => '这是title2' tag =>array( array( id =3, name => 'tag3') ),),)
这样的数据?
ps:就像本站的列表是怎么显示的标签的?
回复内容: list和tag都是数据库里的数据,想要用mysql这样的查询语句查询出来,得到下面的查询结果,在不用foreach这样的php循环语句下得到结果
list => array( array(id => 1, title => '这是title'), array(id => 2, title => '这是title2'),)//list_id和list里的id关联tag => array( array(id => 1, list_id = 1, name => 'tag1'), array(id => 2, list_id = 1, name => 'tag2'), array(id => 3, list_id = 2, name => 'tag3'), );
这样的,该怎样查出
select => array(array( id => 1, title => '这是title', tag =>array( array( id =1, name => 'tag1'), array(id=2,name='tag2') ),),array( id => 2, title => '这是title2' tag =>array( array( id =3, name => 'tag3') ),),)
这样的数据?
ps:就像本站的列表是怎么显示的标签的?
select posts.id as post_id, posts.title as post_title, group_concat(tags.name as tag_name)from posts, tag_posts, tagswhere tag_posts.post_id = posts.idand tag_posts.tag_id = tags.id group by post_title
额,突然明白过来你可能是在问mysql的查询语句..好囧,好像这个需求能用join搞定?select * from `list` left join `tag` on list.id = tag.list_id,这个试试?
$lists = array();foreach($list as $item) $lists[ $item['id'] ] = array('id'=>$item['id], 'title'=>$item['title']);foreach($tag as $item) { $lists[ $item['list_id'] ]['tag'][] = array('id'=>$item['id'], 'name'=>$item['name']);/*为了得到你的问题中的效果,其实这步有点多余。*/$lists = array_values($lists);
