Hierarchische Abfragen in MySQL
Beim Umgang mit hierarchischen Daten besteht die Möglichkeit, Eltern, Großeltern und weitere Vorfahren für einen bestimmten Knoten abzurufen entscheidend. In diesem Artikel wird erläutert, wie dies in MySQL mithilfe einer rekursiven Abfrage erreicht wird.
Angenommen eine Tabelle mit einer Eltern-Kind-Beziehung, die durch die Spalten a und b dargestellt wird, können wir die folgende Abfrage verwenden, um alle Vorfahren einer bestimmten Tabelle zu finden Knoten, unabhängig von ihrer Tiefe:
SELECT @id := (SELECT senderid FROM mytable WHERE receiverid = @id) AS person FROM ( SELECT @id := 5 ) vars STRAIGHT_JOIN mytable WHERE @id IS NOT NULL
Diese Abfrage beginnt mit einer Unterabfrage, die die @id-Variable auf den bereitgestellten Knoten setzt (5 in diesem Beispiel). Die äußere Abfrage verknüpft dann die Tabelle anhand dieser Variablen und durchläuft die Hierarchie effektiv nach oben, bis keine übergeordneten Elemente mehr vorhanden sind. Die STRAIGHT_JOIN-Syntax stellt sicher, dass die Abfrage von oben nach unten erfolgt.
Das Ergebnis der Abfrage ist eine Liste von Vorfahren für den angegebenen Knoten, wobei der Stammvorfahre zuerst aufgeführt wird:
1 2 3 4
Durch das Verständnis dieses Ansatzes können Entwickler effektiv durch hierarchische Strukturen in MySQL navigieren und so komplexe Abfragen für Daten mit Eltern-Kind-Beziehungen durchführen. Dies ist besonders wertvoll für Anwendungen, die von Stammbäumen bis hin zu Organisationshierarchien reichen.
Das obige ist der detaillierte Inhalt vonWie kann ich mithilfe rekursiver Abfragen alle Vorfahren eines Knotens in einer hierarchischen MySQL-Datenbank abrufen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!