Heim > Datenbank > MySQL-Tutorial > Warum gibt mein MySQL LEFT JOIN nicht alle Zeilen zurück?

Warum gibt mein MySQL LEFT JOIN nicht alle Zeilen zurück?

Barbara Streisand
Freigeben: 2024-12-22 13:22:14
Original
883 Leute haben es durchsucht

Why Doesn't My MySQL LEFT JOIN Return All Rows?

Left Join gibt nicht alle Zeilen zurück: MySQL-Abfrageproblem

In MySQL wird häufig eine LEFT JOIN-Operation verwendet, um Zeilen aus zwei Tabellen zu kombinieren basierend auf einem gemeinsamen Schlüssel. In bestimmten Szenarios wie dem in dieser Frage beschriebenen kann es jedoch sein, dass die Abfrage nicht alle erwarteten Zeilen zurückgibt.

Struktur und Problem der Abfrage

Das Problem tritt auf, wenn das WHERE Die WHERE-Klausel wird direkt auf die Join-Bedingung angewendet, wie in der ursprünglichen Abfrage zu sehen ist:

SELECT pr.*, pr7.value AS `room_price_high`
FROM `jos_hp_properties` pr
LEFT OUTER JOIN `jos_hp_properties2` pr7 ON pr7.property=pr.id
WHERE pr7.field=23
Nach dem Login kopieren

In diesem Fall beschränkt die WHERE-Klausel den Join darauf, nur Zeilen zurückzugeben wobei pr7.field = 23. Dadurch werden alle Zeilen in der Tabelle jos_hp_properties ausgeschlossen, die keinen passenden pr7.field-Eintrag mit dem Wert 23 haben. Dies führt dazu, dass die Abfrage weniger Zeilen als erwartet zurückgibt.

Lösung: Verschieben der WHERE-Bedingung

Um das Problem zu beheben und sicherzustellen, dass alle Zeilen ab der ersten Tabelle zurückgegeben werden, sollte die WHERE-Bedingung wie folgt in die ON-Bedingung des JOIN verschoben werden:

SELECT pr.*, pr7.value AS `room_price_high`
FROM `jos_hp_properties` pr
LEFT JOIN `jos_hp_properties2` pr7 ON pr7.property=pr.id
AND pr7.field=23
Nach dem Login kopieren

Durch das Verschieben der Bedingung in den JOIN stellt die Abfrage zunächst den linken Join zwischen den Tabellen her und Filtert dann die verbundenen Zeilen basierend auf den angegebenen Kriterien. Dadurch wird sichergestellt, dass alle Zeilen aus der Tabelle jos_hp_properties im Ergebnissatz enthalten sind, unabhängig davon, ob sie einen passenden Eintrag in der Tabelle jos_hp_properties2 mit pr7.field = 23 haben.

Das obige ist der detaillierte Inhalt vonWarum gibt mein MySQL LEFT JOIN nicht alle Zeilen zurück?. 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