Операции LEFT JOIN, RIGHT JOIN

Применяется к
Access для Microsoft 365 Access 2024 Access 2021 Access 2019 Access 2016

Объединяют записи исходных таблиц при использовании в любом предложении FROM.

Синтаксис

FROM table1 [ LEFT | RIGHT ] JOIN table2
ON table1.field1compopr table2.field2

Операции LEFT JOIN и RIGHT JOIN состоят из следующих элементов:

Часть Описание
таблица1, таблица2 Имена таблиц, содержащих объединяемые записи.
поле1, поле2 Имена объединенных полей. Поля должны иметь один тип данных и содержать один и тот же тип данных, но они не должны иметь одно и то же имя.
compopr Любой оператор реляционного сравнения: "=", "<," ">," "<=", ">=" или "<>".

      

Замечания

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

Используйте операцию RIGHT JOIN для создания правого внешнего соединения. С помощью правого внешнего соединения выбираются все записи второй (правой) таблицы, даже если они не соответствуют записям в первой (левой) таблице.

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

В следующем примере показано, как можно объединить таблицы Categories и Products по полю CategoryID. Результат запроса представляет собой список категорий, включая те, которые не содержат товаров.

SELECT CategoryName, ProductName FROM Categories LEFT JOIN Products ON Categories.CategoryID = Products.CategoryID;

В этом примере CategoryID является присоединенным полем, но не включается в результаты запроса, так как он не включен в инструкцию SELECT. Чтобы включить присоединенное поле, введите имя поля в инструкции SELECT— в данном случае Categories.CategoryID.

Чтобы создать запрос, результатом которого являются только те записи, для которых совпадают данные в связующих полях, воспользуйтесь операцией INNER JOIN.

  • Операции LEFT JOIN и RIGHT JOIN могут быть вложены в операцию INNER JOIN, но операция INNER JOIN не может быть вложена в операцию LEFT JOIN или RIGHT JOIN. Подробные сведения о вложении объединений можно найти в статье, посвященной операции INNER JOIN.
  • Вы можете связать несколько предложений ON. Сведения о связывании предложений см. в статье, посвященной операции INNER JOIN.

При попытке связи полей, содержащих данные типа Memo или объекты OLE, возникнет ошибка.