在我的网站上,我有三大部分:人们可以开始讨论的部分,他们可以分享故事的部分以及我自己写的文章的博客。我使用下面的数据库结构构建了一个自定义标记系统。
在我的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"
现在我想通过讨论,故事和文章展示整个网站上最受欢迎的标签。有没有人可以帮我这个?我已经工作了好几个小时,似乎无法找到解决方案..谢谢!
答案 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;