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;
Связанные термины
Анекдоты по теме
Собеседование. Спрашивают: — В чём разница между LEFT JOIN и LEFT OUTER JOIN? Кандидат молчит 10 секунд. — Это одно и то же. Интервьюер: — Правильно. Просто хотел посмотреть на твоё лицо.
ORM приходит к психотерапевту: — Я генерирую запросы. Терапевт: — И что в этом плохого? ORM: — 500 JOIN на пустой таблице. Терапевт: — А lazy loading пробовали? ORM: — Тогда 500 отдельных запросов. Терапевт: — Вам нужен DBA.
Разработчик смотрит на код коллеги: SELECT * FROM a, b WHERE a.id = b.a_id — Это что, неявный JOIN? — Синтаксис из 1992 года. — Оно работает? — Да. Но использовать — моветон.