SQLite - JOINS
SQLite JoinsKlausel wird verwendet, um Datensätze aus zwei oder mehr Tabellen in einer Datenbank zu kombinieren. Ein JOIN ist ein Mittel zum Kombinieren von Feldern aus zwei Tabellen unter Verwendung gemeinsamer Werte.
SQL definiert drei Haupttypen von Verknüpfungen:
- Das CROSS JOIN
- Der INNERE JOIN
- Der OUTER JOIN
Bevor wir fortfahren, betrachten wir zwei Tabellen COMPANY und DEPARTMENT. Wir haben bereits INSERT-Anweisungen zum Auffüllen der COMPANY-Tabelle gesehen. Nehmen wir also einfach die Liste der in der COMPANY-Tabelle verfügbaren Datensätze an -
ID NAME AGE ADDRESS SALARY
---------- ---------- ---------- ---------- ----------
1 Paul 32 California 20000.0
2 Allen 25 Texas 15000.0
3 Teddy 23 Norway 20000.0
4 Mark 25 Rich-Mond 65000.0
5 David 27 Texas 85000.0
6 Kim 22 South-Hall 45000.0
7 James 24 Houston 10000.0
Eine andere Tabelle ist DEPARTMENT mit der folgenden Definition:
CREATE TABLE DEPARTMENT(
ID INT PRIMARY KEY NOT NULL,
DEPT CHAR(50) NOT NULL,
EMP_ID INT NOT NULL
);
Hier ist die Liste der INSERT-Anweisungen zum Auffüllen der DEPARTMENT-Tabelle:
INSERT INTO DEPARTMENT (ID, DEPT, EMP_ID)
VALUES (1, 'IT Billing', 1 );
INSERT INTO DEPARTMENT (ID, DEPT, EMP_ID)
VALUES (2, 'Engineering', 2 );
INSERT INTO DEPARTMENT (ID, DEPT, EMP_ID)
VALUES (3, 'Finance', 7 );
Schließlich haben wir die folgende Liste von Datensätzen in der Tabelle DEPARTMENT -
ID DEPT EMP_ID
---------- ---------- ----------
1 IT Billing 1
2 Engineering 2
3 Finance 7
Das CROSS JOIN
CROSS JOIN vergleicht jede Zeile der ersten Tabelle mit jeder Zeile der zweiten Tabelle. Wenn die Eingabetabellen eine x- bzw. eine y-Zeile haben, hat die resultierende Tabelle eine x * y-Zeile. Da CROSS JOINs das Potenzial haben, extrem große Tabellen zu generieren, muss darauf geachtet werden, diese nur bei Bedarf zu verwenden.
Es folgt die Syntax von CROSS JOIN -
SELECT ... FROM table1 CROSS JOIN table2 ...
Basierend auf den obigen Tabellen können Sie einen CROSS JOIN wie folgt schreiben:
sqlite> SELECT EMP_ID, NAME, DEPT FROM COMPANY CROSS JOIN DEPARTMENT;
Die obige Abfrage führt zu folgendem Ergebnis:
EMP_ID NAME DEPT
---------- ---------- ----------
1 Paul IT Billing
2 Paul Engineering
7 Paul Finance
1 Allen IT Billing
2 Allen Engineering
7 Allen Finance
1 Teddy IT Billing
2 Teddy Engineering
7 Teddy Finance
1 Mark IT Billing
2 Mark Engineering
7 Mark Finance
1 David IT Billing
2 David Engineering
7 David Finance
1 Kim IT Billing
2 Kim Engineering
7 Kim Finance
1 James IT Billing
2 James Engineering
7 James Finance
Der INNERE JOIN
INNER JOIN erstellt eine neue Ergebnistabelle, indem die Spaltenwerte zweier Tabellen (Tabelle1 und Tabelle2) basierend auf dem Join-Prädikat kombiniert werden. Die Abfrage vergleicht jede Zeile von Tabelle1 mit jeder Zeile von Tabelle2, um alle Zeilenpaare zu finden, die das Join-Prädikat erfüllen. Wenn das Join-Prädikat erfüllt ist, werden die Spaltenwerte für jedes übereinstimmende Zeilenpaar von A und B zu einer Ergebniszeile kombiniert.
Ein INNER JOIN ist der häufigste und standardmäßigste Join-Typ. Sie können das Schlüsselwort INNER optional verwenden.
Es folgt die Syntax von INNER JOIN -
SELECT ... FROM table1 [INNER] JOIN table2 ON conditional_expression ...
Um Redundanz zu vermeiden und die Phrasierung kürzer zu halten, können INNER JOIN-Bedingungen mit a deklariert werden USINGAusdruck. Dieser Ausdruck gibt eine Liste mit einer oder mehreren Spalten an.
SELECT ... FROM table1 JOIN table2 USING ( column1 ,... ) ...
Ein NATURAL JOIN ähnelt einem JOIN...USINGEs wird nur automatisch geprüft, ob die Werte jeder Spalte in beiden Tabellen gleich sind.
SELECT ... FROM table1 NATURAL JOIN table2...
Basierend auf den obigen Tabellen können Sie einen INNER JOIN wie folgt schreiben:
sqlite> SELECT EMP_ID, NAME, DEPT FROM COMPANY INNER JOIN DEPARTMENT
ON COMPANY.ID = DEPARTMENT.EMP_ID;
Die obige Abfrage führt zu folgendem Ergebnis:
EMP_ID NAME DEPT
---------- ---------- ----------
1 Paul IT Billing
2 Allen Engineering
7 James Finance
Der OUTER JOIN
OUTER JOIN ist eine Erweiterung von INNER JOIN. Obwohl der SQL-Standard drei Arten von OUTER JOINs definiert: LEFT, RIGHT und FULL, unterstützt SQLite nur dieLEFT OUTER JOIN.
OUTER JOINs haben eine Bedingung, die mit INNER JOINs identisch ist und mit einem Schlüsselwort ON, USING oder NATURAL ausgedrückt wird. Die anfängliche Ergebnistabelle wird auf die gleiche Weise berechnet. Sobald der primäre JOIN berechnet ist, nimmt ein OUTER JOIN alle nicht verbundenen Zeilen aus einer oder beiden Tabellen, füllt sie mit NULL-Werten auf und hängt sie an die resultierende Tabelle an.
Es folgt die Syntax von LEFT OUTER JOIN -
SELECT ... FROM table1 LEFT OUTER JOIN table2 ON conditional_expression ...
Um Redundanz zu vermeiden und die Phrasierung kürzer zu halten, können OUTER JOIN-Bedingungen mit einem USING-Ausdruck deklariert werden. Dieser Ausdruck gibt eine Liste mit einer oder mehreren Spalten an.
SELECT ... FROM table1 LEFT OUTER JOIN table2 USING ( column1 ,... ) ...
Basierend auf den obigen Tabellen können Sie einen inneren Join wie folgt schreiben:
sqlite> SELECT EMP_ID, NAME, DEPT FROM COMPANY LEFT OUTER JOIN DEPARTMENT
ON COMPANY.ID = DEPARTMENT.EMP_ID;
Die obige Abfrage führt zu folgendem Ergebnis:
EMP_ID NAME DEPT
---------- ---------- ----------
1 Paul IT Billing
2 Allen Engineering
Teddy
Mark
David
Kim
7 James Finance