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