Heim > Datenbank > MySQL-Tutorial > SQL JOIN: WHERE vs. ON: Was ist der Hauptunterschied beim Filtern verbundener Daten?

SQL JOIN: WHERE vs. ON: Was ist der Hauptunterschied beim Filtern verbundener Daten?

Susan Sarandon
Freigeben: 2025-01-23 02:49:11
Original
762 Leute haben es durchsucht

SQL JOIN: WHERE vs. ON: What's the Key Difference in Filtering Joined Data?

SQL JOIN: WHERE- und ON-Klauseln verstehen

Um SQL JOINs zu beherrschen, ist ein klares Verständnis der WHERE- und ON-Klauseln erforderlich. Obwohl sie manchmal austauschbar sind, unterscheiden sich ihre Funktionen erheblich.

WHEREKlausel: Post-Join-Filterung

Die WHERE-Klausel filtert die Ergebnisse eines Joins. Betrachten Sie dieses Beispiel:

<code class="language-sql">SELECT *
FROM Orders
LEFT JOIN OrderLines ON OrderLines.OrderID = Orders.ID
WHERE Orders.ID = 12345;</code>
Nach dem Login kopieren

Hier filtert die WHERE-Klausel die Ausgabe und zeigt nur Zeilen an, in denen Orders.ID 12345 ist. Dies gilt nachdem das LEFT JOIN Daten aus Orders und OrderLines kombiniert hat.

ON Klausel: Definition der Join-Bedingung

Die ON-Klausel definiert die Join-Bedingung selbst. Beachten Sie:

<code class="language-sql">SELECT *
FROM Orders
LEFT JOIN OrderLines ON OrderLines.OrderID = Orders.ID AND Orders.ID = 12345;</code>
Nach dem Login kopieren

Die ON-Klausel schreibt vor, dass nur Zeilen in den Join einbezogen werden, in denen OrderLines.OrderID mit Orders.ID übereinstimmt und Orders.ID 12345 entspricht. Diese Filterung erfolgt währenddes Beitrittsprozesses.

Schlüsselsemantische Unterscheidung

Obwohl WHERE und ON mit INNER JOINs zu ähnlichen Ergebnissen führen könnten, sind ihre semantischen Rollen unterschiedlich. WHERE filtert den endgültigen verbundenen Datensatz, während ON bestimmt, welche Zeilen in den Verknüpfungsvorgang einbezogen werden.

Das obige ist der detaillierte Inhalt vonSQL JOIN: WHERE vs. ON: Was ist der Hauptunterschied beim Filtern verbundener Daten?. 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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage