Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

Consulta SQL para selecionar postagens pertencentes a várias categorias


Este é divisão relacional .

Use GROUP BY e COUNT ou duplo NOT EXISTS .

Um exemplo da primeira abordagem seria.
SELECT pt.Post_id, p.Post_Text
FROM Post_Tags pt
JOIN Posts p ON p.Post_id = pt.Post_id
WHERE pt.Tag_id IN (1,2,3)
GROUP BY pt.Post_id
HAVING COUNT(DISTINCT pt.Tag_id) = 3