我有topic(id *)和tags(id *,name)和一个链接表topic_tags(topicFk *,tagFk *)。
现在,我想选择每个具有所有良好标签(a,b,c)但没有不良标签(d,e,f)的主题。
我怎么做?
问题来源于stack overflow
假设您的Topic_Tags表是唯一的,这可以回答您的确切问题-但可能无法推广到您的实际问题:
SELECT TopicId FROM Topic_Tags JOIN Tags ON Topic_Tags.TagId = Tags.TagId WHERE Tags.Name IN ('A', 'B', 'C', 'D', 'E', 'F') GROUP BY TopicId HAVING COUNT(*) = 3 AND MAX(Tags.Name) = 'C' 一个更通用的解决方案是:
SELECT * FROM ( SELECT TopicId FROM Topic_Tags JOIN Tags ON Topic_Tags.TagId = Tags.TagId WHERE Tags.Name IN ('A', 'B', 'C') GROUP BY TopicId HAVING COUNT(*) = 3 ) as GoodTags LEFT JOIN ( SELECT TopicId FROM Topic_Tags JOIN Tags ON Topic_Tags.TagId = Tags.TagId WHERE Tags.Name = 'D' OR Tags.Name = 'E' OR Tags.Name = 'F' ) as BadTags ON GoodTags.TopicId = BadTags.TopicId WHERE BadTags.TopicId IS NULL
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。