Problem:
Durchqueren einer hierarchischen Struktur, wie z Stücklistentabelle, erfordert eine Methode zum rekursiven Abrufen von Zeilen, um eine verschachtelte Baumdarstellung zu erstellen. Herkömmliche SQL-Abfragen sind jedoch nur begrenzt in der Lage, Rekursionen zu verarbeiten.
Antwort:
Im Jahr 2011 wurde auf DBA StackExchange eine Frage gepostet, in der nach einer MySQL-Lösung für Tree gesucht wurde Durchquerung. Die Antwort lieferte eine Reihe gespeicherter Prozeduren:
Implementierung:
Aufruf GetFamilyTree(item_id), um den Stammbaum für ein bestimmtes Element abzurufen. Diese gespeicherte Prozedur findet rekursiv das übergeordnete Element und alle Vorfahren und gibt die Ergebnisse als geschichtete Baumstruktur zurück.
Beispiel:
CREATE PROCEDURE GetFamilyTree( IN item_id INT ) BEGIN SELECT ... # Perform recursive tree traversal END;
Verwendung:
CALL GetFamilyTree(1);
Dadurch wird der gesamte Stammbaum für Element 1 abgerufen und verschachtelt dargestellt Format.
Vorteile:
Das obige ist der detaillierte Inhalt vonWie baut man rekursiv eine Baumstruktur aus hierarchischen MySQL-Daten auf?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!