यह मानते हुए कि आपकी 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