Задать вопрос
dmitrydeco
@dmitrydeco

MySQL: выбор похожих записей по категориям. Как?

Привет, товарищи. Совсем запутался с запросом, вроде бы лёгкий.
Есть посты, у каждого поста могут быть категории. Связаны между собой через промежуточную таблицу 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)
  • Вопрос задан
  • 216 просмотров
Подписаться 1 Оценить Комментировать
Помогут разобраться в теме Все курсы
  • Skillbox
    Веб-разработчик на PHP
    9 месяцев
    Далее
  • Хекслет
    PHP-разработчик
    10 месяцев
    Далее
  • Нетология
    Веб-разработчик с нуля: профессия с выбором специализации
    14 месяцев
    Далее
Решения вопроса 1
Rsa97
@Rsa97
Для правильного вопроса надо знать половину ответа
Пригласить эксперта
Ответы на вопрос 1
sam002
@sam002
Линуксойд, кодер, немного физик.
SELECT t.* FROM posts t 
    INNER JOIN post_category pc ON ( t.id = pc.post_id)
WHERE pc.category_id IN (1,2,4)
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
FoodSoul Калининград
от 180 000 до 250 000 ₽
IT-Spirit Москва
от 230 000 до 320 000 ₽
от 200 000 до 290 000 ₽