Teradata - dołącza
Łączenie służy do łączenia rekordów z więcej niż jednej tabeli. Tabele są łączone na podstawie wspólnych kolumn / wartości z tych tabel.
Dostępne są różne typy połączeń.
- Połączenie wewnętrzne
- Lewe połączenie zewnętrzne
- Prawe połączenie zewnętrzne
- Pełne połączenie zewnętrzne
- Dołącz do siebie
- Łączenie krzyżowe
- Dołączenie produkcji kartezjańskiej
WEWNĘTRZNE DOŁĄCZENIE
Łączenie wewnętrzne łączy rekordy z wielu tabel i zwraca wartości istniejące w obu tabelach.
Składnia
Poniżej znajduje się składnia instrukcji INNER JOIN.
SELECT col1, col2, col3….
FROM
Table-1
INNER JOIN
Table-2
ON (col1 = col2)
<WHERE condition>;
Przykład
Weź pod uwagę poniższą tabelę pracowników i tabelę wynagrodzeń.
Pracownik numer | Imię | Nazwisko | JoinedDate | DepartmentNo | Data urodzenia |
---|---|---|---|---|---|
101 | Mikrofon | James | 27.03.2005 | 1 | 05.01.1980 |
102 | Robert | Williams | 25.04.2007 | 2 | 05.03.1983 |
103 | Piotr | Paweł | 21.03.2007 | 2 | 01.04.1983 |
104 | Alex | Stuart | 01.02.2008 | 2 | 06.11.1984 |
105 | Robert | James | 1/4/2008 | 3 | 01.12.1984 |
Pracownik numer | obrzydliwy | Odliczenie | Płaca netto |
---|---|---|---|
101 | 40 000 | 4000 | 36.000 |
102 | 80 000 | 6000 | 74 000 |
103 | 90 000 | 7,000 | 83 000 |
104 | 75 000 | 5000 | 70 000 |
Następujące zapytanie łączy tabelę Employee i Salary we wspólnej kolumnie EmployeeNo. Do każdej tabeli przypisany jest alias A i B, a odwołania do kolumn są wskazywane przez właściwy alias.
SELECT A.EmployeeNo, A.DepartmentNo, B.NetPay
FROM
Employee A
INNER JOIN
Salary B
ON (A.EmployeeNo = B. EmployeeNo);
Po wykonaniu powyższego zapytania zwraca następujące rekordy. Pracownik 105 nie jest uwzględniany w wyniku, ponieważ nie ma pasujących rekordów w tabeli Wynagrodzenie.
*** Query completed. 4 rows found. 3 columns returned.
*** Total elapsed time was 1 second.
EmployeeNo DepartmentNo NetPay
----------- ------------ -----------
101 1 36000
102 2 74000
103 2 83000
104 2 70000
DOŁĄCZ ZEWNĘTRZNE
LEFT OUTER JOIN i RIGHT OUTER JOIN również łączą wyniki z wielu tabel.
LEFT OUTER JOIN zwraca wszystkie rekordy z lewej tabeli i zwraca tylko pasujące rekordy z prawej tabeli.
RIGHT OUTER JOIN zwraca wszystkie rekordy z prawej tabeli i zwraca tylko pasujące wiersze z lewej tabeli.
FULL OUTER JOINłączy wyniki zarówno LEWEGO ZEWNĘTRZNEGO, jak i PRAWEGO ZEWNĘTRZNEGO STAWÓW. Zwraca zarówno pasujące, jak i niepasujące wiersze z połączonych tabel.
Składnia
Poniżej znajduje się składnia instrukcji OUTER JOIN. Musisz użyć jednej z opcji LEFT OUTER JOIN, RIGHT OUTER JOIN lub FULL OUTER JOIN.
SELECT col1, col2, col3….
FROM
Table-1
LEFT OUTER JOIN/RIGHT OUTER JOIN/FULL OUTER JOIN
Table-2
ON (col1 = col2)
<WHERE condition>;
Przykład
Rozważmy następujący przykład zapytania LEFT OUTER JOIN. Zwraca wszystkie rekordy z tabeli Pracownik i pasujące rekordy z tabeli Wynagrodzenie.
SELECT A.EmployeeNo, A.DepartmentNo, B.NetPay
FROM
Employee A
LEFT OUTER JOIN
Salary B
ON (A.EmployeeNo = B. EmployeeNo)
ORDER BY A.EmployeeNo;
Kiedy powyższe zapytanie jest wykonywane, generuje następujące dane wyjściowe. Dla pracownika 105 wartość NetPay wynosi NULL, ponieważ nie ma pasujących rekordów w tabeli wynagrodzeń.
*** Query completed. 5 rows found. 3 columns returned.
*** Total elapsed time was 1 second.
EmployeeNo DepartmentNo NetPay
----------- ------------ -----------
101 1 36000
102 2 74000
103 2 83000
104 2 70000
105 3 ?
CROSS JOIN
Łączenie krzyżowe łączy każdy wiersz z lewej tabeli do każdego wiersza z prawej tabeli.
Składnia
Poniżej znajduje się składnia instrukcji CROSS JOIN.
SELECT A.EmployeeNo, A.DepartmentNo, B.EmployeeNo,B.NetPay
FROM
Employee A
CROSS JOIN
Salary B
WHERE A.EmployeeNo = 101
ORDER BY B.EmployeeNo;
Kiedy powyższe zapytanie jest wykonywane, generuje następujące dane wyjściowe. Pracownik nr 101 z tabeli Pracownik jest łączony z każdym rekordem z Tabeli wynagrodzeń.
*** Query completed. 4 rows found. 4 columns returned.
*** Total elapsed time was 1 second.
EmployeeNo DepartmentNo EmployeeNo NetPay
----------- ------------ ----------- -----------
101 1 101 36000
101 1 104 70000
101 1 102 74000
101 1 103 83000