Heim >Datenbank >MySQL-Tutorial >Warum gibt mein MySQL LEFT JOIN nicht alle Zeilen zurück?
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
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
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!