开发者社区> 问答> 正文

MySQL的减号?

我有topic(id *)和tags(id *,name)和一个链接表topic_tags(topicFk *,tagFk *)。

现在,我想选择每个具有所有良好标签(a,b,c)但没有不良标签(d,e,f)的主题。

我怎么做?

问题来源于stack overflow

展开
收起
保持可爱mmm 2019-11-18 16:44:42 598 0
1 条回答
写回答
取消 提交回答
  • 假设您的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

    2019-11-18 16:44:50
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
从花农到MySQL大 立即下载
从华农到MySQL大神 立即下载
深入MySQL实战 立即下载