JOINНачальный
RIGHT JOIN
Возвращает все строки из правой таблицы. Для строк без пары в левой — NULL.
Синтаксис
SELECT ... FROM t1 RIGHT JOIN t2 ON t1.id = t2.t1_id;
Объяснение
RIGHT JOIN — зеркало LEFT JOIN. На практике используется редко: обычно можно переписать порядок таблиц и использовать LEFT JOIN.
RIGHT JOIN и LEFT JOIN — синонимы при перестановке таблиц: A RIGHT JOIN B = B LEFT JOIN A.
Пример
-- Эквивалентные запросы SELECT * FROM orders o RIGHT JOIN users u ON u.id = o.user_id; -- То же самое: SELECT * FROM users u LEFT JOIN orders o ON o.user_id = u.id;
Связанные термины
Анекдоты по теме
Разработчик: — У меня запрос на 8 таблиц через JOIN, подзапросы, оконные функции внутри WHERE и GROUP BY на хэш с миллиардом строк. Он идёт 3 дня. Как оптимизировать? DBA: — TRUNCATE TABLE карьера_разработчика. И иди в менеджеры.
ORM приходит к психотерапевту: — Я генерирую запросы. Терапевт: — И что в этом плохого? ORM: — 500 JOIN на пустой таблице. Терапевт: — А lazy loading пробовали? ORM: — Тогда 500 отдельных запросов. Терапевт: — Вам нужен DBA.
Приходит JOIN к врачу: — Доктор, я перемножаю таблицы, и у меня из 1000 строк стало 1000000. Врач: — Ты забыл условие. Это CROSS JOIN. Оно неизлечимо.