Якщо до запиту Access включено кілька джерел даних, об'єднання використовуються, щоб обмежити записи, які мають відображатися, залежно від того, як джерела даних пов'язані між собою. Можна також використовувати об’єднання для записів з обох джерел даних, так що кожна пара записів з джерел стає одним записом у результатах запиту.
У цій статті розглядаються різні типи об’єднання і показується, як використовувати їх у запитах. За замовчуванням об'єднання створюється автоматично, якщо вже існує зв'язок між двома джерелами даних, які використовуються в запиті. Об'єднання також створюється, якщо є поля, які чітко відповідають одне одному. Ви можете видалити автоматично створене об'єднання. У цій статті наведено основні відомості про зв'язки між таблицями, зокрема про те, як їх створити.
Примітка.: Ви можете об'єднувати запити так само, як об'єднувати таблиці, а також об'єднувати їх.
У цій статті
Огляд
База даних – це колекція таблиць даних, які мають логічні зв'язки між собою. Зв'язки використовуються для з'єднання таблиць за спільними полями. Таблиця може бути частиною будь-якої кількості зв'язків, але кожен зв'язок завжди має лише дві таблиці. У запиті зв'язок представлено об'єднанням.
Під час додавання таблиць до запиту Access створює об'єднання на основі зв'язків, визначених між таблицями. Ви можете вручну створювати об'єднання в запитах, навіть якщо вони не відповідають вже визначеним зв'язкам. Якщо як джерела даних для запиту використовуються інші запити (замість таблиць або на додачу до них), можна створити об'єднання між вихідними запитами, а також між цими запитами та будь-якими таблицями, які використовуються як джерела даних.
Об'єднання працюють так само, як умови запиту, коли встановлюють правила, які мають збігатися з даними, які потрібно включити в операції запиту. На відміну від умов, об'єднання також визначають, що кожна пара рядків, які відповідають умовам об'єднання, буде об'єднано в наборі записів, щоб сформувати один рядок.
Існують чотири основні типи об’єднань: внутрішні об’єднання, зовнішні об’єднання, перехресні об’єднання і порівняльні об’єднання. У цій статті описано кожен тип об'єднання, який можна використовувати, чому ви використовуєте кожен тип і як створювати об'єднання.
Об’єднання призначене для запитів, зв’язаних із таблицями: визначаючи те, як дані з двох джерел можуть бути об’єднані на основі спільних значень даних. Тут наведена ілюстрація об’єднання в запиті в режимі конструктора, де показані відкриті у діалоговому вікні параметри об’єднання:
Ця лінія між таблицями являє собою об’єднання. Двічі клацніть об’єднання, щоб відкрити діалогове вікно Параметри об’єднання (показане) і перегляньте або змініть об’єднання.
Об’єднання іноді є спрямованим. Ця область у діалоговому вікні показує, які таблиці знаходяться в об’єднанні, і поля, які використовуються для об’єднання таблиць.
Ця область визначає тип об’єднання: параметр 1 є внутрішнім об’єднанням, 2 є лівим зовнішнім об’єднанням, а 3 є правим зовнішнім об’єднанням.
Можна використати поля з обох таблиць і відобразити з кожної таблиці дані, які відносяться до даного завдання. У внутрішньому об’єднанні ніяких інших даних немає. У зовнішнього об’єднання в результати запиту також включені не пов’язані записи з однієї таблиці.
Типи об’єднань
Існують чотири основні типи об’єднань: внутрішні об’єднання, зовнішні об’єднання, перехресні об’єднання і порівняльні об’єднання. Перехресні і порівняльні об’єднання приєднується є складними типами об’єднань і використовуються рідко, але ви повинні знати про них, щоб мати повне уявлення про те, як об’єднання працює.
Внутрішні об’єднання: використовуються лише пов’язані дані з обох таблиць
Внутрішнє об’єднання в Access використовує лише дані з таблиці, якщо є відповідні дані в пов’язаній таблиці, і навпаки. Частіше за все ви будете використовувати внутрішні об’єднання. Якщо створено об’єднання і не вказано його тип, Access припускає, що ви створюєте внутрішнє об’єднання. Внутрішні об’єднання корисні тим, що вони дають змогу об’єднати дані з двох джерел на основі спільних значень – тож що ви бачите дані тільки коли є повна картина.
Зовнішні об’єднання: правильно поєднуються всі пов’язані дані, а також решта записів з однієї таблиці
Зовнішнє об’єднання схоже на внутрішнє об’єднання, але з додаванням решти рядків з однієї з таблиць. Зовнішні об’єднання є спрямованими: ліве зовнішнє об’єднання використовує всі записи з лівої таблиці – першої таблиця в об’єднанні, а праве зовнішнє об’єднання використовує всі записи з правої таблиці – другої таблиці в об’єднанні.
Повне зовнішнє об’єднання: усі дані об’єднуються, якщо це можливо
У деяких системах зовнішнє об’єднання може задіяти всі рядки з обох таблиць, коли рядки об’єднуються зі своїми відповідниками. Це називається повним зовнішнім об’єднанням і Access не підтримує його явно. Однак для досягнення того ж ефекту ви можете використати перехресне об’єднання й умови.
Перехресне об’єднання: усі дані об’єднуються всіма можливими способами
Частіше за все перехресне об’єднання є побічним ефектом ситуації, коли у запит додають дві таблиці, а потім забувають об’єднати їх. Access інтерпретує це так, ніби ви хочете побачити всі записи з однієї таблиці в поєднанні з усіма записами з іншої таблиці – всі можливі комбінації записів. Бо жодні дані не вдається об’єднати, цей вид об’єднання рідко дає корисні результати. Але в кількох ситуаціях перехресне об’єднання є саме тим, що вам потрібно.
Порівняльне об’єднання: аналогічне звичайному об’єднанню, але під час об’єднання виконується порівняння рядків
У порівняльному об’єднанні використовується оператор, відмінний від знака рівності (=) для порівняння значень і визначення, чи потрібно об’єднати ці дані. Порівняльне об’єднання не підтримується явно, але для досягнення цього ж ефекту ви можете використати перехресне об’єднання й умови.
Відображення рядків, у яких є спільне значення в обох об'єднуваних таблицях
Якщо ви хочете показувати тільки ті рядки, які містять в об’єднуваному полі значення, що збігаються, можна використовувати внутрішнє об’єднання. Access створює внутрішні об’єднання автоматично.
Внутрішні об’єднання є найбільш поширеним типом об’єднання. Вони повідомляють запиту, що рядки з однієї з об'єднуваних таблиць відповідають рядкам в іншій таблиці на основі даних у об'єднуваних полях. Коли виконується запит із внутрішнім об’єднанням, тільки ті рядки, у яких містяться спільні значення в обох об’єднуваних таблицях, будуть включені в операції запиту.
Як можна використовувати внутрішнє об’єднання?
У більшості випадків вам не потрібно робити нічого для використання внутрішнього об’єднання. Якщо додані в запит таблиці вже мають зв’язки, Access автоматично створює внутрішнє об’єднання між кожною парою зв’язаних таблиць під час додавання таблиць. Якщо цілісність зв’язків є обов’язковою, Access також відображає "1" над лінією об’єднання, щоб показати, яка з таблиць знаходиться на стороні "один" у зв’язок "один-до-багатьох", а символ нескінченності (∞), щоб показати, яка таблиця знаходиться на стороні "багатьох".
Навіть якщо зв'язки ще не створено, Access автоматично створює внутрішні об'єднання, якщо додати до запиту дві таблиці, а в кожній із них є поле з однаковим або сумісним типом даних, а одне з полів об'єднання – це первинний ключ. Символи "один" і "багато" в цьому випадку не відображаються, оскільки цілісність зв’язків не обов’язкова.
Якщо ви додаєте запити у свій запит і не створили зв’язки між цими запитами, Access автоматично не створює внутрішнього об’єднання між цими запитами або між запитами і таблицями. Як правило, ви повинні створити їх самостійно. Щоб створити внутрішнє об'єднання, перетягніть поле з одного джерела даних до поля в іншому джерелі даних. Access відобразить лінію між двома полями, щоб показати, що об’єднання створено.
Синтаксис SQL для внутрішнього об’єднання
Внутрішні об’єднання в SQL визначаються реченням FROM, як показано нижче:
FROM таблиця1 INNER JOIN таблиця2 ON таблиця1.поле1 порівняти таблицю2.поле2
Операція INNER JOIN складається з таких частин:
Частина |
Опис |
таблиця1, таблиця2 |
Імена таблиць, записи яких буде об’єднано. |
поле1, поле2 |
Імена об’єднаних полів. Якщо поля не числові, вони повинні мати однаковий тип даних, але не повинні мати однакові імена. |
compare |
Будь-який реляційний оператор порівняння: "=", "<", ">", "<=", ">=" або "<>" |
Додаткові відомості про синтаксис операції INNER JOIN можна знайти в розділі Операція INNER JOIN.
Відображення всіх рядків з однієї таблиці та відповідних рядків з іншої таблиці
Зовнішнє об'єднання повідомляє запиту, що хоча деякі рядки з обох сторін об'єднання відповідають точно, запит має містити всі рядки з однієї таблиці, а також ті рядки з іншої таблиці, які мають спільне значення з обох сторін об'єднання.
Зовнішнє об’єднання може бути лівим зовнішнім об’єднанням або правим зовнішнім об’єднанням. У лівому зовнішньому об’єднанні запит включає в себе всі рядки з першої таблиці в реченні FROM інструкції SQL і тільки ті рядки з іншої таблиці, у яких об’єднуване поле містить значення, спільні для обох таблиць. У правому зовнішньому об’єднанні запит включає в себе всі рядки з другої таблиці в реченні FROM інструкції SQL і тільки ті рядки з іншої таблиці, у яких об’єднуване поле містить значення, спільні для обох таблиць.
Примітка.: Можна легко визначити ліву і праву таблиці в даному об’єднанні, двічі клацнувши об’єднання і переглянувши діалогове вікно Параметри об’єднання. Також можна перейти в режим SQL, а потім перевірити речення FROM.
Оскільки деякі з рядків на одній стороні зовнішнього об’єднання не будуть мати відповідних рядків з іншої таблиці, деякі з полів, які повертаються в результатах запиту з тієї іншої таблиці, будуть пустими, якщо рядки не збігаються.
Як можна використовувати зовнішнє об’єднання?
Можна створити зовнішнє об’єднання шляхом зміни існуючого внутрішнього об’єднання. Якщо внутрішнього об’єднання не існує, створіть його, а потім змініть його на зовнішнє об’єднання.
Зміна внутрішнього об’єднання на зовнішнє об’єднання
-
У режимі конструктора запиту двічі клацніть об’єднання, яке потрібно змінити.
Відкриється діалогове вікно Параметри об’єднання.
-
У діалоговому вікні Параметри об’єднання зверніть увагу на значення параметра 2 і параметра 3.
-
Виберіть параметр, який ви хочете використовувати, і натисніть кнопку OK.
-
Access відображає об’єднання і стрілку, яка вказує на джерело даних, де всі рядки будуть включені в джерело даних, у яке будуть включені тільки ті рядки, які задовольняють умові об’єднання.
Неоднозначне зовнішнє об’єднання
Якщо ви створили запит, який містить параметри LEFT JOIN та INNER JOIN, Access не зможе визначити, яку операцію об’єднання слід виконати в першу чергу. Оскільки результати відрізняються залежно від того, чи виконується перше ліве об'єднання або внутрішнє об'єднання, Access відображає повідомлення про помилку:
Щоб виправити цю помилку, потрібно змінити запит, щоб було зрозуміло, яке об'єднання потрібно спочатку виконати.
Синтаксис SQL для зовнішнього об’єднання
Зовнішні об’єднання в SQL визначаються в реченні FROM, як показано нижче:
FROM таблиця1 [ LEFT | RIGHT ] JOIN таблиця2
ON таблиця1.поле1 порівняти таблицю2.поле2Операції LEFT JOIN і RIGHT JOIN складаються з таких частин:
Частина |
Опис |
таблиця1, таблиця2 |
Імена таблиць, записи яких буде об’єднано. |
поле1, поле2 |
Імена об’єднаних полів. Поля повинні мати однаковий тип даних, але не повинні мати однакові імена. |
compare |
Будь-який реляційний оператор порівняння: "=", "<", ">", "<=", ">=" або "<>" |
Додаткові відомості про синтаксис зовнішнього об’єднання можна знайти в наведених нижче статтях Операції LEFT JOIN, RIGHT JOIN.
Відображати всі рядки з обох таблиць і об'єднувати їх там, де існує спільне значення
Якщо потрібно відобразити всі рядки з двох таблиць і об'єднати їх на основі спільних значень, використовуйте повне зовнішнє об'єднання. Access явно не підтримує повне зовнішнє об'єднання, але ви можете досягти такого ж ефекту, використовуючи запит на об'єднання. У наведеній нижче процедурі пояснюється, як це зробити, але якщо вам потрібні додаткові відомості про запити на об'єднання, див. розділ Див. також .
Щоб скористатися запитом на об'єднання для виконання повного зовнішнього об'єднання, виконайте наведені нижче дії.
-
Створіть запит, який має ліве зовнішнє об'єднання в полі, яке потрібно використовувати для повного зовнішнього об'єднання.
-
На вкладці Основне у групі Подання натисніть кнопку Вигляд і виберіть пункт Режим SQL.
-
Натисніть клавіші Ctrl+C, щоб скопіювати код SQL.
-
Видаліть крапку з комою в кінці речення FROM і натисніть клавішу Enter.
-
Введіть UNION і натисніть клавішу Enter.
Примітка.: Не використовуйте ключове слово ALL, якщо використовується запит на об'єднання для виконання повного зовнішнього об'єднання.
-
Натисніть клавіші Ctrl+V, щоб вставити код SQL, скопійований на кроці 3.
-
У вставленому коді змініть left JOIN на RIGHT JOIN.
-
Видаліть крапку з комою в кінці другого речення FROM, а потім натисніть клавішу Enter.
-
Додайте речення WHERE, яке вказує, що значення поля об'єднання має NULL-значення в першій таблиці, указаній у реченні FROM (ліва таблиця).
Наприклад, якщо речення FROM:
FROM Products RIGHT JOIN [Order Details]
ON Products.ID = [Order Details].[Product ID]Додайте таке речення WHERE:
WHERE Products.ID IS NULL
-
Введіть крапку з комою (;) в кінці речення WHERE, щоб позначити кінець запиту на об'єднання.
-
На вкладці Конструктор у групі Результати натисніть кнопку Запуск.
Перехресні об'єднання
Перехресні об'єднання відрізняються від внутрішніх і зовнішніх об'єднань тим, що вони явно не представлені в Access. У перехресному об'єднанні кожен рядок з однієї таблиці поєднується з кожним рядком з іншої таблиці, що призводить до того, що називається перехресним продуктом або декартового продукту. Щоразу, коли виконується запит із таблицями, які явно не об'єднуються, результатом буде перехресний продукт. Перехресні об'єднання зазвичай ненавмисні, але бувають випадки, коли вони можуть бути корисними.
Навіщо потрібно використовувати перехресне об’єднання?
Якщо ви збираєтеся вивчити всі можливі комбінації рядків двох таблиць або запитів, використайте перехресне об’єднання. Припустімо, наприклад, що у вашого бізнесу був вражаючий рік, і ви плануєте подарувати знижки клієнтам. Ви можете створити запит, який підсумовує замовлення кожного клієнта, створити невелику таблицю, яка містить кілька можливих варіантів відсотка знижки, а також об’єднати обидві таблиці в іншому запиті, який виконує перехресне об’єднання. Ви в кінцевому підсумку запит, який відображає набір гіпотетичних відшкодування для кожного клієнта.
Як я можу використовувати перехресне об’єднання?
Перехресне об'єднання створюється в будь-який час, коли ви включаєте таблиці або запити в запит і не створюєте принаймні одне явне об'єднання для кожної таблиці або запиту. Access об'єднує кожен рядок із кожної таблиці або запиту, який явно не з'єднано з будь-якою іншою таблицею або запитом, до будь-якого іншого рядка в результатах. Розглянемо сценарій знижки з попереднього абзацу. Припустимо, у вас є 91 клієнт, і ви хочете подивитися на п’ять можливих варіантів знижки. Перехресне об'єднання дає 455 рядків (добуток 91 і 5).
Як ви можете собі уявити, ненавмисне перехресне об’єднання може згенерувати величезну кількість рядків у результатах запиту. Крім того, ці результати, як правило, безглузді, тому що якщо ви насправді не маєте наміру об'єднувати кожен рядок з кожним іншим рядком, більшість об'єднаних рядків, які відображаються в результатах, не матимуть сенсу. Нарешті, виконання запитів, у яких використовується ненавмисне перехресне об'єднання, може тривати дуже довго.
1. Обведені поля слід об'єднувати один з одним.
1. Зверніть увагу на дуже велику кількість записів.
1. Зверніть увагу, що кількість записів значно менша.
Об'єднання таблиць на основі нерівності значень полів
Об’єднання не повинні бути основані на рівності полів об’єднання. Об’єднання може бути засноване на будь-якому операторі порівняння, такому як більше (>), менше (<) або не дорівнює (<>). Об’єднання, які не засновані на рівності, називають порівняльним об’єднанням.
Якщо ви хочете об’єднати рядки з двох джерел даних на основі значень нееквівалентних полів, можна використати порівняльне об’єднання. Як правило, порівняльне об’єднання засноване на операторах порівняння більше (>), менше (<), більше або дорівнює (>=), або менше або дорівнює (<=). Порівняльне об’єднання, яке засноване на операторі не дорівнює (<>) може повернути майже стільки ж рядків, що й перехресне об’єднання, і результати можуть бути складними для інтерпретації.
Як можна використовувати порівняльне об’єднання?
Нерівні об'єднання не підтримуються в режимі конструктора. Якщо ви хочете використовувати їх, ви повинні зробити це за допомогою режиму SQL. Однак ви можете створити об'єднання в режимі конструктора, перейти до режиму SQL, знайти оператор порівняння дорівнює (=) і змінити його на потрібний оператор. Після цього запит можна знову відкрити в режимі конструктора, лише якщо спочатку змінити оператор порівняння на рівний (=) у режимі SQL.
Видалення об’єднання
Якщо Access автоматично створює небажане об’єднання, або якщо ви помилково створюєте об’єднання – наприклад, об’єднання між двома полями, які містять різнорідні типи даних – ви можете видалити об’єднання.
-
У сітці макета запиту клацніть об’єднання, яке потрібно видалити.
-
Натисніть клавішу Delete.
-або-
-
У сітці макета запиту клацніть правою кнопкою миші об’єднання, яке потрібно видалити, і виберіть пункт Видалити.