Оператор SQL LEFT JOIN осуществляет формирование таблицы из записей двух или нескольких таблиц. В операторе SQL LEFT JOIN, как и в операторе SQL RIGHT JOIN, важен порядок следования таблиц, так как от этого будет зависеть полученный результат. Алгоритм работы оператора следующий:
- Сначала происходит формирование таблицы внутренним соединением (оператор SQL INNER JOIN) левой и правой таблиц
- Затем, в результат добавляются записи левой таблицы не вошедшие в результат формирования таблицы внутренним соединением. Для них, соответствующие записи из правой таблицы заполняются значениями NULL.
Оператор SQL LEFT JOIN имеет следующий синтаксис:
SELECT column_names [,... n] FROM Table_1 LEFT JOIN Table_2 ON condition
Примеры оператора SQL LEFT JOIN. Имеются две таблицы:
Authors — содержит в себе информацию об авторах книг:
AuthorID | AuthorName |
1 | Bruce Eckel |
2 | Robert Lafore |
3 | Andrew Tanenbaum |
Books — содержит в себе информацию о названии книг:
BookID | BookName |
3 | Modern Operating System |
1 | Thinking in Java |
3 | Computer Architecture |
4 | Programming in Scala |
В таблице Books поле BookID являются внешним ключом и ссылаются на таблицу Authors.
Пример 1. Пользуясь оператором SQL LEFT JOIN вывести, какие книги написали все авторы:
SELECT * FROM Authors LEFT JOIN Books ON Authors.AuthorID = Books.BookID
Результирующая таблица будет выглядеть следующим образом:
Authors.AuthorID | Authors.AuthorName | Books.BookID | Books.BookName |
1 | Bruce Eckel | 1 | Thinking in Java |
2 | Robert Lafore | NULL | NULL |
3 | Andrew Tanenbaum | 3 | Modern Operating System |
3 | Andrew Tanenbaum | 3 | Computer Architecture |
Как можно заметить, записи о книгах автора Robert Lafore отсутствуют в базе и поля Books.BookID и Books.BookName дополняются значениями NULL.