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