Heim > Datenbank > MySQL-Tutorial > Warum gibt mein SQL Left Join nur eine Zeile statt aller Zeilen zurück?

Warum gibt mein SQL Left Join nur eine Zeile statt aller Zeilen zurück?

Mary-Kate Olsen
Freigeben: 2024-12-12 13:25:14
Original
230 Leute haben es durchsucht

Why Does My SQL Left Join Only Return One Row Instead of All Rows?

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
Nach dem Login kopieren

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!

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