⊗pyPmDOGD 123 of 129 menu

Datenabfrage aus verknüpften Tabellen in Python

Lassen Sie uns eine Abfrage erstellen, die alle Benutzer zusammen mit ihren Städten abruft. Dafür wird der Befehl LEFT JOIN benötigt:

Seine Syntax sieht folgendermaßen aus:

SELECT Felder FROM Tabellenname LEFT JOIN Name_der_verknüpften_Tabelle ON Verknüpfungsbedingung WHERE Auswahlbedingung

Lassen Sie uns die einzelnen Teile der Syntax dieses Befehls analysieren.

Felder

Da die Abfrage aus mehreren Tabellen erfolgt, wird die Abfrage aller Felder mit * nicht funktionieren. Die folgende Abfrage wählt Felder nur aus der Haupttabelle, nicht aber aus der verknüpften Tabelle:

SELECT *

Damit Daten aus allen Tabellen ausgewählt werden, muss vor * der Tabellenname für die Abfrage angegeben werden:

SELECT users.*, cities.*

Alternativ können die benötigten Felder aufgelistet werden, wobei der Tabellenname vor ihnen angegeben wird:

SELECT users.name, cities.name

Diese beiden Methoden haben ein Problem. Und zwar, wenn Felder in den Tabellen gleiche Namen haben, dann kommt es im Python-Array zu einem Namenskonflikt und es bleibt nur ein Feld übrig, das zweite wird nicht vorhanden sein.

Um das Problem zu lösen, müssen die kollidierenden Namen mit dem Befehl as umbenannt werden:

SELECT users.name, cities.name as city_name

Verknüpfung

Nach dem Befehl ON müssen wir die Felder aus den beiden Tabellen angeben, über die die Verknüpfung hergestellt wird. In unserem Fall sind das das Feld id aus der Tabelle mit den Städten und das Feld city_id aus der Tabelle mit den Benutzern:

ON cities.id=users.city_id

Abfrage

Letztendlich wird die Abfrage, die die Benutzer zusammen mit ihren Städten abruft, folgendermaßen aussehen:

SELECT users.name, cities.name as city_name FROM users LEFT JOIN cities ON cities.id=users.city_id

Praktische Aufgaben

Angenommen, Sie haben eine Tabelle mit Produkten und eine Tabelle mit deren Kategorien. Schreiben Sie eine Abfrage, die die Produktnamen zusammen mit ihren Kategorien abruft.

Deutsch
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Wir verwenden Cookies für den Betrieb der Website, Analyse und Personalisierung. Die Datenverarbeitung erfolgt gemäß der Datenschutzerklärung.
alle akzeptieren anpassen ablehnen