如何找到每个页面的所有标签,然后将标签连接成一列?
Posted
技术标签:
【中文标题】如何找到每个页面的所有标签,然后将标签连接成一列?【英文标题】:How to find all the tags of each page and then concat the tags into one column? 【发布时间】:2011-12-29 23:58:53 【问题描述】:如何找到每个页面的所有标签,然后将标签拼接成一列?
举个例子,
页表,
page_id
1
2
3
4
标签表,
tag_id tag_name
1 A
2 B
3 C
4 D
标记表,
page_id tag_id
1 1
1 2
1 3
3 2
3 3
我的工作查询,
SELECT
p.page_id,
GROUP_CONCAT(t.tag_name ORDER BY t.tag_name ASC SEPARATOR ",") AS tags
FROM root_pages AS p
LEFT JOIN root_mm_pages_tags AS m
ON p.page_id = m.page_id
LEFT JOIN root_tags AS t
ON t.tag_id = m.tag_id
WHERE p.page_id = t.page_id
这是我想要的结果,
page_id tags
1 A, B, C
2 NULL
3 B, C
4 NULL
【问题讨论】:
+1 以正确的方式进行多对多操作。 感谢 NullUserException! :-) 【参考方案1】:不用ON p.page_id = tt.page_id
和WHERE p.page_id = t.page_id
试试;也将最后一个加入作为常规加入以提高性能。
SELECT
p.page_id,
GROUP_CONCAT(t.tag_name ORDER BY t.tag_name ASC SEPARATOR ",") AS tags
FROM root_pages AS p
LEFT JOIN root_mm_pages_tags AS m
ON p.page_id = m.page_id
JOIN root_tags AS t
ON t.tag_id = m.tag_id
GROUP BY p.page_id
【讨论】:
抱歉`ON p.page_id = tt.page_id`是我的错误。 np。毕竟快到周末了……哦等等。 我试过你的答案,但它只返回一行在tag
...的列中有重复的标签...:(
@lauthiamkok 我们可以查看您的表格转储,以便我们有一些数据可以测试吗?
哦,我通过在查询末尾添加这一行 GROUP BY p.page_id
:-)以上是关于如何找到每个页面的所有标签,然后将标签连接成一列?的主要内容,如果未能解决你的问题,请参考以下文章