SQL-Abfrage gibt nicht alle Zeilen mit Left Join zurück
Diese Abfrage zielt darauf ab, alle Zeilen aus der Tabelle jos_hp_properties (abgekürzt als pr) abzurufen mit dem Wert aus der Tabelle jos_hp_properties2 (abgekürzt als pr7), wobei das Feld mit dem Namen field gleich 23 ist in der letztgenannten Tabelle. Allerdings gibt die aktuelle Abfrage nur eine einzige Zeile zurück, obwohl die Tabelle „jos_hp_properties“ 27 Zeilen enthält.
Um dieses Problem zu beheben, sollte die WHERE-Klausel wie folgt in die JOIN-Anweisung 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
Mit dieser geänderten Abfrage schränkt die WHERE-Klausel die Ergebnismenge vor dem Join nicht mehr ein. Stattdessen werden Zeilen aus der Tabelle jos_hp_properties einbezogen, auch wenn es in der Tabelle jos_hp_properties2 keine entsprechende Zeile für Feld 23 gibt (in diesem Fall ist der zurückgegebene Wert NULL). Dadurch wird sichergestellt, dass alle Zeilen aus der ersten Tabelle zurückgegeben werden, zusammen mit den gewünschten Daten aus der zweiten Tabelle, sofern zutreffend.
Das obige ist der detaillierte Inhalt vonWarum gibt mein SQL Left Join nur eine Zeile statt aller Zeilen zurück?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!