Heim > Datenbank > MySQL-Tutorial > WHERE vs. ON in SQL JOINs: Wann sollte ich die einzelnen Klauseln verwenden?

WHERE vs. ON in SQL JOINs: Wann sollte ich die einzelnen Klauseln verwenden?

DDD
Freigeben: 2025-01-05 13:10:44
Original
272 Leute haben es durchsucht

WHERE vs. ON in SQL JOINs: When Should I Use Each Clause?

Untersuchung der Unterschiede zwischen WHERE-Klausel und ON-Bedingung in JOIN

SQL-Anwender verwenden die WHERE-Klausel und die ON-Bedingung häufig austauschbar, wenn sie JOIN-Operationen durchführen . Obwohl beide Ansätze die gleichen Ergebnisse liefern können, müssen einige Nuancen berücksichtigt werden.

Im bereitgestellten Beispiel werden zwei SQL-Abfragen dargestellt:

SELECT *
FROM Foo AS f
INNER JOIN Bar AS b ON b.BarId = f.BarId
WHERE b.IsApproved = 1;
Nach dem Login kopieren

und

SELECT *
FROM Foo AS f
INNER JOIN Bar AS b ON (b.IsApproved = 1) AND (b.BarId = f.BarId);
Nach dem Login kopieren

Beide Abfragen geben denselben Zeilensatz zurück, es gibt jedoch einen entscheidenden Unterschied in ihrer Ausführung. Wenn der Filter in der WHERE-Klausel platziert wird, wird er nach der JOIN-Operation angewendet. Dies bedeutet, dass der JOIN alle übereinstimmenden Zeilen aus beiden Tabellen abruft, auch diejenigen, bei denen b.IsApproved den Wert „false“ hat. Die WHERE-Klausel filtert dann die Zeilen heraus, die das Kriterium b.IsApproved = 1 nicht erfüllen.

Im Gegensatz dazu wird, wenn der Filter in die ON-Bedingung gesetzt wird, die Bedingung vor dem JOIN ausgewertet. Daher werden nur Zeilen in den JOIN aufgenommen, in denen sowohl b.BarId als auch b.IsApproved die angegebenen Kriterien erfüllen.

Äußere Verknüpfungen und Filterplatzierung

Allerdings Dieser Unterschied wird besonders wichtig, wenn es um äußere Verknüpfungen geht. Betrachten Sie die folgende Left-Outer-Join-Abfrage:

SELECT *
FROM Foo AS f
LEFT OUTER JOIN Bar AS b ON (b.IsApproved = 1) AND (b.BarId = f.BarId);
Nach dem Login kopieren

In diesem Fall schließt der Filter in der ON-Bedingung Zeilen aus, in denen b.IsApproved falsch ist oder in denen es keine passende b.BarId für ein bestimmtes f gibt .BarId. Dieses Verhalten unterscheidet sich von der Platzierung des Filters in der WHERE-Klausel:

SELECT *
FROM Foo AS f
LEFT OUTER JOIN Bar AS b ON (b.BarId = f.BarId)
WHERE b.IsApproved = 1;
Nach dem Login kopieren

In der zweiten Abfrage werden weiterhin Zeilen zurückgegeben, in denen b.IsApproved falsch ist oder die einen fehlgeschlagenen Join betreffen, b.IsApproved jedoch auf NULL gesetzt werden.

Daher ist es bei der Verwendung von Outer-Joins wichtig, die Platzierung von Filtern sorgfältig zu prüfen. Die ON-Bedingung filtert Zeilen vor dem Join, während die WHERE-Klausel die Ergebnisse nach dem Join filtert.

Um die Diskussion abzuschließen: Wenn Sie einen OPTIONAL-Filter in einem linken Outer-Join wünschen, zeigt die folgende Abfrage die korrekte Platzierung :

SELECT *
FROM Foo AS f
LEFT OUTER JOIN Bar AS b ON (b.BarId = f.BarId)
WHERE b.IsApproved IS NULL OR b.IsApproved = 1;
Nach dem Login kopieren

Diese Abfrage gibt Zeilen zurück, in denen die Verknüpfung erfolgreich war und b.IsApproved das Kriterium erfüllt, sowie Zeilen, in denen die Verknüpfung fehlschlägt (was zu einem NULL-Wert führt). Wert für b.IsApproved).

Das obige ist der detaillierte Inhalt vonWHERE vs. ON in SQL JOINs: Wann sollte ich die einzelnen Klauseln verwenden?. 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