Heim > Datenbank > MySQL-Tutorial > Left Join vs. Inner Join: Wie wirkt sich eine WHERE-Klausel auf die Ergebnisse eines Left Joins aus?

Left Join vs. Inner Join: Wie wirkt sich eine WHERE-Klausel auf die Ergebnisse eines Left Joins aus?

DDD
Freigeben: 2025-01-03 18:53:44
Original
1079 Leute haben es durchsucht

Left Join vs. Inner Join: How Does a WHERE Clause Affect a Left Join's Results?

Left Join vs. Inner Join

In SQL sind Left Joins und Inner Joins zwei grundlegende Join-Typen, die unterschiedliche Ergebnismengen liefern. Ein Left-Join gibt alle Zeilen aus der linken Tabelle zurück und gleicht Zeilen aus der rechten Tabelle basierend auf einer Join-Bedingung ab. Wenn keine Übereinstimmung gefunden wird, werden die fehlenden Werte in der rechten Tabelle als NULL-Werte dargestellt. Im Gegensatz dazu gibt ein innerer Join nur Zeilen zurück, die die Join-Bedingung erfüllen, und schließt Zeilen aus beiden Tabellen aus, die diese Bedingung nicht erfüllen.

Änderung des Verhaltens von Links-Joins

In die bereitgestellte SQL-Abfrage:

SELECT
a.foo
b.bar
c.foobar
FROM tableOne AS a
INNER JOIN tableTwo AS b ON a.pk = b.fk
LEFT JOIN tableThree AS c ON b.pk = c.fk
WHERE a.foo = 'something'
AND c.foobar = 'somethingelse'
Nach dem Login kopieren

Das Vorhandensein der WHERE c.foobar = 'somethingelse'-Klausel nach dem LEFT Die JOIN-Bedingung hat einen überraschenden Effekt. Es scheint den linken Join in einen inneren Join umzuwandeln, was dazu führt, dass keine Zeilen zurückgegeben werden, wenn „somethingelse“ nicht in tableThree vorhanden ist.

Erklärung

Das scheint seltsam Verhalten ergibt sich aus der Auswertungsreihenfolge von SQL-Anweisungen. Die WHERE-Klausel wird verarbeitet, nachdem die Verknüpfungen durchgeführt wurden. Wenn daher c.foobar = 'somethingelse' in der WHERE-Klausel angegeben wird, werden effektiv alle Zeilen aus dem linken Join herausgefiltert, bei denen c.foobar NULL ist. Infolgedessen werden nur Zeilen im endgültigen Ergebnissatz beibehalten, in denen c.foobar mit dem angegebenen Wert („somethingelse“) übereinstimmt.

Lösung

Um das Gewünschte beizubehalten Für das Left-Join-Verhalten gibt es zwei Optionen:

  1. Ändern Sie die WHERE-Klausel so, dass sie OR c.foobar IS enthält NULL, wie unten gezeigt:

    WHERE a.foo = 'something'
    AND (c.foobar = 'somethingelse' OR c.foobar IS NULL)
    Nach dem Login kopieren

    Dadurch können Zeilen, in denen c.foobar NULL ist, in die Ergebnismenge aufgenommen werden.

  2. Verschieben Sie c.foobar = „somethingelse“-Vergleich in die ON-Klausel des linken Joins ein, um sicherzustellen, dass nur Zeilen, die diese Bedingung erfüllen, im Ergebnis enthalten sind eingestellt:

    LEFT JOIN tableThree AS c ON b.pk = c.fk AND c.foobar = 'somethingelse'
    Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonLeft Join vs. Inner Join: Wie wirkt sich eine WHERE-Klausel auf die Ergebnisse eines Left Joins aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage