如何从规范化表中获得最流行的标签?

时间:2016-02-22 13:21:36

标签: mysql sql

在我的网站上,我有三大部分:人们可以开始讨论的部分,他们可以分享故事的部分以及我自己写的文章的博客。我使用下面的数据库结构构建了一个自定义标记系统。

a busy cat

在我的tags_xref表中,每个帖子类型需要有3个不同的列,因为讨论可以与故事或文章具有相同的ID。

一切都正常工作,但我遇到查询问题以显示某些标签。我已经知道如何在讨论部分中展示最受欢迎的标签:

"SELECT t.id, t.tag, COUNT(discussion_id) AS cnt
    FROM tags_xref AS xrf
    INNER JOIN tags AS t ON xrf.tag_id = t.id
    GROUP BY t.id, t.tag
    ORDER BY COUNT(discussion_id) DESC LIMIT 20"

现在我想通过讨论,故事和文章展示整个网站上最受欢迎的标签。有没有人可以帮我这个?我已经工作了好几个小时,似乎无法找到解决方案..谢谢!

1 个答案:

答案 0 :(得分:4)

您可以对查询进行简单修改:

SELECT t.id, t.tag, COUNT(*) AS cnt
FROM tags_xref xrf INNER JOIN
     tags t
     ON xrf.tag_id = t.id
GROUP BY t.id, t.tag
ORDER BY COUNT(*) DESC
LIMIT 20;

据推测,当各种ID不合适时,它们是NULL。如果出于某种奇怪的原因,您实际上为给定的外部参照存储了所有三个ID中的值,您可以这样做:

SELECT t.id, t.tag,
       (COUNT(story_id) + COUNT(discussion_id) + COUNT(article_id) ) AS cnt
FROM tags_xref xrf INNER JOIN
     tags t
     ON xrf.tag_id = t.id
GROUP BY t.id, t.tag
ORDER BY cnt DESC
LIMIT 20;