通过包含和排除标签来选择项目

时间:2019-03-05 12:30:24

标签: mysql select tags

请考虑以下架构:

id | question
-----------
1  | How old are you?
2  | Are you a male or female?

question_tag:

id | question_id | tag_id
--------------------------
1  | 1       | 1
2  | 1       | 2
3  | 1       | 3
4  | 2       | 1
5  | 2       | 2

tags:

id | tag
--------------
1  | some_tag
2  | some_other_tag
3  | different_tag

问题和标签之间有很多关系。

我想选择所有带有特定标签而没有其他标签的问题。

例如两个标签都为[1,2]但没有标签为[3]的问题

我目前拥有的是:

select `questions`.`id`,
       `questions`.`question`,
from `questions`
       inner join `question_tag` on `questions`.`id` = `question_tag`.`question_id`
  where `tag_id` in (1,2)
group by `questions`.`id`, `questions`.`question`
having count(tag_id) = 2;

“包含”部分有效-我只得到同时包含两个标签的问题。

现在我需要添加“排除”部分-例如过滤我们的问题,这些问题也具有tag_id = 3。

我尝试添加AND tag_id NOT IN (3)失败了-这些问题并未从结果中滤除。

知道我想念什么吗?

1 个答案:

答案 0 :(得分:1)

您可以尝试使用不存在的相关子查询

select `questions`.`id`,
       `questions`.`question`,
from `questions`
       inner join `question_tag` on `questions`.`id` = `question_tag`.`question_id`
  where  `tag_id` in (1,2) and not exists (select 1 from question_tag x where `question_tag`.`question_id`=x.`question_id` and x.tag_id=3)
group by `questions`.`id`, `questions`.`question`