Объединяют записи исходных таблиц при использовании в любом предложении 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, возникнет ошибка.