当前位置:  开发笔记 > 编程语言 > 正文

如何查找具有最常见标记的记录,例如StackOverflow中的相关问题

如何解决《如何查找具有最常见标记的记录,例如StackOverflow中的相关问题》经验,为你挑选了1个好方法。

我们可以在StackOverflow网站上用多个标签标记一个问题,我想知道如何找出与常见标签最相关的问题.

假设我们在数据库中有100个问题,每个问题都有几个标签.假设用户正在浏览特定问题,我们希望系统在页面上显示相关问题.相关问题的标准是它们具有最常见的标签.

例如:问题1标有AAA,BBB,CCC,DDD,EEE.

问题2与前1相关,因为它也包含所有这5个标签.问题3与前2相关,因为它只有Questio1有4或3个标签.......

所以我的问题是如何设计数据库并快速找出与问题1相关的问题.非常感谢你.



1> Tony Andrews..:

也许是这样的:

select qt.question_id, count(*)
from   question_tags qt
where  qt.tag in
( select qt2.tag
  from   question_tags qt2
  where  qt2.question_id = 123
)
group by qt.question_id
order by 2 desc

推荐阅读
可爱的天使keven_464
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有