SQL LEFT JOIN Ключевое слово. Пример left join


База Данных MySQL LEFT JOIN

Ключевое слово соединения SQL Left

Ключевое слово LEFT JOIN возвращает все записи из левой таблицы (Table1) и совпадающие записи из правой таблицы (Table2). Результат равен NULL с правой стороны, если совпадений нет.

LEFT JOIN Синтаксис

SELECT column_name(s)FROM table1LEFT JOIN table2 ON table1.column_name = table2.column_name;

Note: In some databases LEFT JOIN is called LEFT OUTER JOIN.

Демонстрационная база данных

В этом учебнике мы будем использовать хорошо известную базу данных Northwind Sample.

Ниже представлен выбор из таблицы "Customers":

CustomerID CustomerName ContactName Address City PostalCode Country
1 Alfreds Futterkiste Maria Anders Obere Str. 57 Berlin 12209 Germany
2 Ana Trujillo Emparedados y helados Ana Trujillo Avda. de la Constitución 2222 México D.F. 05021 Mexico
3 Antonio Moreno Taquería Antonio Moreno Mataderos 2312 México D.F. 05023 Mexico

And a selection from the "Orders" table:

OrderID CustomerID EmployeeID OrderDate ShipperID
10308 2 7 1996-09-18 3
10309 37 3 1996-09-19 1
10310 77 8 1996-09-20 2

Пример левого соединения SQL

Следующая инструкция SQL выберет всех клиентов и любые заказы, которые они могут иметь:

Пример

SELECT Customers.CustomerName, Orders.OrderIDFROM CustomersLEFT JOIN Orders ON Customers.CustomerID = Orders.CustomerIDORDER BY Customers.CustomerName;

Примечание: Ключевое слово LEFT JOIN возвращает все записи из левой таблицы (Customers), даже если в правой таблице нет совпадений (Orders).

html5css.ru

Что быстрей LEFT JOIN или подзапрос в SELECT

Часто требуется выбрать дополнительные параметры плюсом к основной выборке. Это можно сделать двумя способами:
  • LEFT JOIN к основному запросу
  • Подзапрос в секции SELECT
Пример запроса, выбирающего номенклатуру и товарную группу номенклатуры:

Подзапрос в секции SELECT:

SELECT nom.Наименование, (SELECT tg.Наименование FROM Товарная группа tg WHERE tg.ID = nom.Товарная группа) FROM Номенклатура nom Вариант с LEFT JOIN: SELECT nom.Наименование, tg.Наименование FROM Номенклатура nom LEFT JOIN Товарная группа tg ON(tg.ID = nom.Товарная группа) После разбора плана выполнения запроса в MS SQL Server, было выявлено:
  • При выборке в секции SELECT требуется дополнительное время на слияние основной выборки и подзапроса. Вышло 1% от общего времени.(+ LEFT JOIN / - SELECT)
  • Оказалось, что каждый LEFT JOIN выполняется отдельным потоком! В то время как подзапросы выполняются последовательно после основной выборки. (+ LEFT JOIN / - SELECT)
  • Каждый LEFT JOIN объединяется в результирующую выборку, что требует дополнительной памяти. В то время как подзапрос вернет нам одно значение на каждую строку, т.е. для получения результата нам нужно меньше памяти. (- LEFT JOIN / + SELECT)
Вывод: В условиях многоядерных серверов LEFT JOIN имеет неоспоримые преимущества

Ограничения в подзапросах:При выборке дополнительных параметров в секции SELECT мы можем столкнуться с ситуацией, когда подзапрос вернул нам более одной записи. Отсечь это можно, указав принудительно число выбираемых записей:

SELECT nom.Наименование, (SELECT TOP 1 tg.Наименование FROM Товарная группа tg WHERE tg.ID = nom.Товарная группа) FROM Номенклатура nom Такой запрос выполнялся дольше на 96% по сравнению с аналогичным без TOP 1

Разбор плана показал, что 1% дополнительного времени тратится вложенный цикл, а 95% на просмотр определенных строк не кластеризованного индекса!Из этого можно сделать один вывод: никогда не используйте без надобности ограничения в подзапросах.

В заключении хотел бы сказать, что бывают ситуации когда без подзапросов не обойтись (группировки, сортировки и т.д.), но использовать их нужно обосновано, если есть возможность, то лучше пользоваться LEFT JOIN.

blog.skahin.ru

MySQL: Join, Left Join, Right Join или «Джоины простыми словами»

Сегодня я решил поведать Вам о языке запросов MySQL, а точнее о конструкции JOIN, которая, как правило, и вызывает недопонимание о начинающих разработчиков…На самом деле в данных командах нет ничего сложного. Давайте рассмотрим их на примере. Двух простых таблиц.

Таблица 1 (groups)

Id Name
1 Гость
2 Администратор
3 Зарегистрированный

Таблица 2 (users)

Id Login Group
1 Admin 2
2 Vasa 3
2 Petya 4

Запросы вида таблица1 JOIN таблица2 — являются декартовым произведением строк из указанных таблиц. Если вы не знаете или не помните что такое декартово произведение, то напомню — это ничто иное объедение всех элементов одного множества, с элементами другого множества. Т.е. запрос вида

SELECT * FROM users JOIN groups

Вернет нам 3*3=9 строк (каждой строке из таблицы users будет сопоставлена строка из таблица groups).В результате мы увидим нечто похожее на:

Id Login Group Id Name
1 Admin 2 1 Гость
1 Admin 2 2 Администратор
1 Admin 2 3 Зарегистрированный
2 Vasa 3 1 Гость
и т.д.

Однако такие «полные» джоины редкость. Обычно запрос Join сопровождается правилом стыковки строк из двух таблиц. В нашем случае в таблице users колонка Group является вторичным ключем на поле Id в таблицы groups. Таким образом правильный запрос для нашего случая будет выглядеть так:

SELECT u.*, g.Name FROM users u JOIN groups g ON u.Group = g.Id

Результат запроса:

Id Login Group Name
1 Admin 2 Администратор
2 Vasa 3 Зарегистрированный

Как мы видим. В выборку не попал пользователь с логином Petya. Объясняется это тем, что данный пользователь имеет группу 4, в то время как в таблице group записи с таким Id не существует. В результате этого Вы можете «потерять» некоторые свои данные при работе с JOIN.

Соответственно возникает вопрос, а как же получить всех пользователей и их группы? Ответ прост, именно для таких случаев и реализованы запросы LEFT JOIN, RIGHT JOIN. Логика работы данных запросов одинакова, но они зависимы от расположения имен таблиц слева и справа от них (в запросе JOIN такой зависимости нет).

Что же делает LEFT JOIN? Данный запрос берет все строчки из таблицы, написанной слева от данной конструкции и приписывает к ней соответствующие строчки из таблицы, приписанной справа от данной конструкции. При этом, если соответствующая строчка в правой таблице не найдена (например как для юзера Petya), то припишутся NULL столбцы.

SELECT u.*, g.Name FROM users u LEFT JOIN groups g ON u.Group = g.Id

Результат запроса:

Id Login Grpup Name
1 Admin 2 Администратор
2 Vasa 3 Зарегистрированный
3 Petya 4 NULL

RIGHT JOIN работает абсолютно аналогично как и LEFT JOIN, только берутся все строчки из таблицы, стоящей справа от этой конструкции. Таким образом чтобы получить RIGHT JOIN с использованием LEFT JOIN достаточно лишь поменять положение таблиц относительно данной конструкции, например, описанные ниже запросы идентичны:

SELECT * FROM table1 LEFT JOIN table2; SELECT * FROM table2 RIGHT JOIN table1;

blog.foolsoft.ru