sql >> Base de Datos >  >> RDS >> Mysql

Consulta SQL para seleccionar publicaciones que pertenecen a múltiples categorías

Esto es división relacional .

Utilice GROUP BY y COUNT o doble NOT EXISTS .

Un ejemplo del primer enfoque sería.

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