Привет, товарищи. Совсем запутался с запросом, вроде бы лёгкий.
Есть посты, у каждого поста могут быть категории. Связаны между собой через промежуточную таблицу post_category (id, post_id, category_id)
Ну так вот. К примеру, у поста есть категории с ID 1,2,4. Мне нужно найти все остальные посты, которые привязаны к категориям 1,2 и 4, но которые могут иметь и другие категории помимо этих. Работает такой вариант, но, может, его можно оптимизировать?
SELECT t.* FROM posts t
RIGHT JOIN post_category pc ON ( t.id = pc.post_id AND pc.category_id = 1)
RIGHT JOIN post_category pc1 ON ( t.id = pc1.post_id AND pc1.category_id = 2)