Получить данные из нескольких таблиц

Отображение данных из нескольких таблиц

Связанные таблицы большой базы данных связаны с помощью внешних и первичных ключей или того, что часто называют общими столбцами. Возможность объединения таблиц позволит вам добавить больше смысла в создаваемую таблицу результатов. Для объединения n таблиц чисел в запросе необходимы минимальные (n-1) условия соединения. На основе условий соединения Oracle объединяет совпадающую пару строк и отображает ту, которая удовлетворяет условию соединения.

Объединения классифицируются следующим образом

  • Естественное соединение (также известное как равное соединение или простое соединение) - создает соединение с использованием обычно именованного и определенного столбца.

  • Соединение без равенства - объединяет таблицы, когда в таблицах, которые нужно объединить, нет эквивалентных строк, например, для сопоставления значений в одном столбце таблицы с диапазоном значений в другой таблице.

  • Самостоятельное присоединение - присоединяет таблицу к самой себе.

  • Внешнее соединение - включает записи таблицы в вывод, если в другой таблице нет соответствующей записи.

  • Декартово соединение (также известное как декартово произведение или перекрестное соединение) - реплицирует каждую строку из первой таблицы с каждой строкой из второй таблицы. Создает соединение между таблицами, отображая все возможные комбинации записей.

Естественное соединение

Ключевое слово NATURAL может упростить синтаксис Equijoin. NATURAL JOIN возможно, когда две (или более) таблицы имеют столбцы с одинаковыми именами, и столбцы совместимы с объединением, т. Е. Столбцы имеют общий домен значений. операция объединяет строки из таблиц, которые имеют одинаковые значения столбцов для столбцов с одинаковыми именами.

Рассмотрим отношение «один ко многим» между таблицами DEPARTMENTS и EMPLOYEES. Каждая таблица имеет столбец с именем DEPARTMENT_ID. Этот столбец является первичным ключом таблицы DEPARTMENTS и внешним ключом таблицы EMPLOYEES.

SELECT E.first_name NAME,D.department_name DNAME
FROM employees E NATURAL JOIN departments D;

FIRST_NAME DNAME
---------- ------
MILLER     DEPT 1
JOHN       DEPT 1
MARTIN     DEPT 2
EDWIN      DEPT 2

Приведенный ниже запрос SELECT объединяет две таблицы путем явного указания условия соединения с ключевым словом ON.

SELECT E.first_name NAME,D.department_name DNAME
FROM employees E JOIN departments D
ON (E.department_id = D.department_id);

В отношении NATURAL JOIN существуют некоторые ограничения. Вы не можете указать столбец LOB с NATURAL JOIN. Кроме того, столбцы, участвующие в объединении, не могут быть уточнены именем таблицы или псевдонимом.

Пункт USING

Используя естественные соединения, Oracle неявно идентифицирует столбцы, чтобы сформировать основу соединения. Во многих ситуациях требуется явное объявление условий соединения. В таких случаях мы используем предложение USING, чтобы указать критерии присоединения. Поскольку предложение USING объединяет таблицы на основе равенства столбцов, оно также известно как Equijoin. Они также известны как внутренние соединения или простые соединения.

Синтаксис:

SELECT <column list>
FROM   TABLE1   JOIN   TABLE2	
USING (column name)

Рассмотрим приведенный ниже запрос SELECT, таблица EMPLOYEES и таблица DEPARTMENTS объединены с использованием общего столбца DEPARTMENT_ID.

SELECT E.first_name NAME,D.department_name DNAME
FROM employees E JOIN departments D
USING (department_id);

Самостоятельное присоединение

Операция SELF-JOIN создает таблицу результатов, когда интересующие отношения существуют между строками, которые хранятся в одной таблице. Другими словами, когда таблица присоединяется к самой себе, это соединение называется самосоединением.

Рассмотрим таблицу EMPLOYEES, которая содержит сотрудников и их менеджеров по отчетности. Чтобы найти имя менеджера для сотрудника, потребуется объединение в самой таблице EMP. Это типичный кандидат на самостоятельное присоединение.

SELECT e1.FirstName Manager,e2.FirstName Employee
FROM employees e1 JOIN employees e2
ON (e1.employee_id = e2.manager_id)
ORDER BY e2.manager_id DESC;

Не эквивалентные соединения

Соединение без равенства используется, когда связанные столбцы не могут быть объединены знаком равенства, что означает, что в таблицах, которые необходимо объединить, нет эквивалентных строк. Соединение с неравенством позволяет сохранить минимальное значение диапазона в одном столбце записи и максимальное значение в другом столбце. Таким образом, вместо поиска совпадения столбца с столбцом вы можете использовать соединение с неравенством, чтобы определить, попадает ли отправляемый элемент между минимальным и максимальным диапазонами в столбцах. плату можно вернуть в результатах. Как и в случае с традиционным методом объединения на равенство, соединение без равенства может быть выполнено в предложении WHERE. Кроме того, ключевое слово JOIN можно использовать с предложением ON для указания соответствующих столбцов для соединения.

SELECT E.first_name,
            J.job_hisal,
            J.job_losal,
            E.salary
     FROM employees E JOIN job_sal J
     ON (E.salary BETWEEN J.job_losal AND J.job_losal);

Мы можем использовать все параметры сравнения, которые обсуждались ранее, такие как операторы равенства и неравенства, BETWEEN, IS NULL, IS NOT NULL и RELATIONAL.

Внешние соединения

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

Существует три типа внешних соединений: LEFT, RIGHT и FULL OUTER JOIN. Все они начинаются с ВНУТРЕННЕГО СОЕДИНЕНИЯ, а затем добавляют обратно некоторые строки, которые были отброшены. LEFT OUTER JOIN добавляет обратно все строки, которые были отброшены из первой (левой) таблицы в условии соединения, а выходные столбцы из второй (правой) таблицы устанавливаются в NULL. ПРАВОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ добавляет обратно все строки, которые были отброшены из второй (правой) таблицы в условии соединения, а выходные столбцы из первой (левой) таблицы устанавливаются в NULL. FULL OUTER JOIN добавляет обратно все строки, удаленные из обеих таблиц.

Правое внешнее соединение

ПРАВОЕ ВНЕШНЕЕ СОЕДИНЕНИЕ добавляет обратно все строки, которые были отброшены из второй (правой) таблицы в условии соединения, а выходные столбцы из первой (левой) таблицы устанавливаются в NULL. Обратите внимание, что в приведенном ниже запросе перечислены сотрудники и соответствующие им отделы. Также в отдел 30 не закреплен ни один сотрудник.

SELECT E.first_name, E.salary, D.department_id          
FROM employees E, departments D
WHERE E.DEPARTMENT_ID (+) = D.DEPARTMENT_ID;

FIRST_NAME SALARY     DEPARTMENT_ID
---------- ---------- ----------
JOHN       6000       10
EDWIN      2000       20
MILLER     2500       10
MARTIN     4000       20
                      30

Левое внешнее соединение

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

SELECT E.first_name, E.salary, D.department_id
FROM employees E, departments D
WHERE   D.DEPARTMENT_ID = E.DEPARTMENT_ID (+);

FIRST_NAME SALARY     DEPARTMENT_ID
---------- ---------- ----------
JOHN       6000       10
EDWIN      2000       20
MILLER     2500       10
MARTIN     4000       20
                      30

Полное внешнее соединение

FULL OUTER JOIN добавляет обратно все строки, удаленные из обеих таблиц. Ниже запрос показывает списки сотрудников и их отделов. Обратите внимание, что сотруднику «MAN» до сих пор не был назначен какой-либо отдел (он NULL), а отдел 30 не назначен ни одному сотруднику.

SELECT  nvl (e.first_name,'-') first_name, nvl (to_char (d.department_id),'-') department_id
FROM employee e FULL OUTER JOIN department d
ON e. depARTMENT_ID = d. depARTMENT_ID;

FIRST_NAME DEPARTMENT_ID
---------- --------------------
MAN        -
JOHN       10
EDWIN      20
MILLER     10
MARTIN     20
-          30

6 rows selected.

Декартово произведение или перекрестное соединение

Для двух сущностей A и B A * B называется декартовым произведением. Декартово произведение состоит из всех возможных комбинаций строк из каждой таблицы. Следовательно, когда таблица с 10 строками соединяется с таблицей с 20 строками, декартово произведение составляет 200 строк (10 * 20 = 200). Например, объединение таблицы сотрудников с восемью строками и таблицы отделов с тремя строками даст таблица декартовых произведений из 24 строк (8 * 3 = 24).

Перекрестное соединение означает декартово произведение двух таблиц. Он производит перекрестное произведение двух таблиц. Вышеупомянутый запрос может быть написан с использованием предложения CROSS JOIN.

Таблица результатов декартовых произведений обычно не очень полезна. На самом деле такая таблица результатов может ввести в заблуждение. Если вы выполните приведенный ниже запрос для таблиц EMPLOYEES и DEPARTMENTS, таблица результатов подразумевает, что каждый сотрудник имеет отношения с каждым отделом, и мы знаем, что это просто не так!

SELECT E.first_name, D.DNAME
FROM employees E,departments D;
Перекрестное соединение можно записать как,
SELECT E.first_name, D.DNAME
FROM employees E CROSS JOIN departments D;