如何找到每个页面的所有标签,然后将标签连接成一列?

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_idWHERE 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 :-)

以上是关于如何找到每个页面的所有标签,然后将标签连接成一列?的主要内容,如果未能解决你的问题,请参考以下文章

如何从 Wordpress 页面/帖子中获取所有标签作为简码列表?

使用 MYSQL 生成分数时如何检查所有连接

如何将excel里一列字分成2列

如何对网站的所有页面使用单头标签

使用 case 语句将多行连接成一列

如何在 Gatsby 中获取所有 Wordpress 帖子和显示标签