请考虑以下架构:
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)
失败了-这些问题并未从结果中滤除。
知道我想念什么吗?
答案 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`