Heim > Backend-Entwicklung > PHP-Tutorial > Wie kann eine rekursive Funktion ein mehrdimensionales Array aus flachen Datenbankergebnissen erstellen?

Wie kann eine rekursive Funktion ein mehrdimensionales Array aus flachen Datenbankergebnissen erstellen?

Linda Hamilton
Freigeben: 2024-12-30 06:15:12
Original
641 Leute haben es durchsucht

How Can a Recursive Function Build a Multidimensional Array from Flat Database Results?

Erzeugen eines mehrdimensionalen Arrays aus Datenbankergebnissen mithilfe einer rekursiven Funktion

Zum Generieren eines verschachtelten Arrays, das hierarchische Daten wie Seiten oder Kategorien darstellt, eine rekursive Funktion wird häufig eingesetzt. Das Ziel besteht darin, ein flaches Array von Datenbankeinträgen zu nehmen und es in ein strukturiertes Array umzuwandeln, das die Eltern-Kind-Beziehungen widerspiegelt.

Rekursive Funktion zur Baumbildung

Das Folgende Die Funktion buildTree erfüllt diese Aufgabe:

def buildTree(elements, parentId=0):
    branch = []
    for element in elements:
        if element['parent_id'] == parentId:
            children = buildTree(elements, element['id'])
            if children:
                element['children'] = children
            branch.append(element)
    return branch
Nach dem Login kopieren

Wie es Funktioniert

  1. Zweig initialisieren: Erstellen Sie für eine bestimmte übergeordnete ID eine leere Zweigliste, um untergeordnete Elemente aufzunehmen.
  2. Über Elemente iterieren :Durchlaufe alle Elemente im flachen Array.
  3. Identifizieren Untergeordnete Elemente: Wenn die parent_id eines Elements mit der aktuellen übergeordneten ID übereinstimmt, ist es ein untergeordnetes Element des Zweigs.
  4. Rekursion für untergeordnete Elemente: Rufen Sie die Funktion rekursiv für das identifizierte untergeordnete Element auf und finden Sie dessen untergeordnetes Element -Kinder.
  5. Zum Zweig hinzufügen:Hängen Sie das untergeordnete Element mit seinen untergeordneten Elementen an (falls beliebig) zur Verzweigungsliste.
  6. Verzweigung zurückgeben: Sobald alle untergeordneten Elemente verarbeitet wurden, wird die ausgefüllte Verzweigungsliste zurückgegeben.

Beispielverwendung

Um Ihre Datenbankeinträge in einem hierarchischen Baum zu verarbeiten, verwenden:

tree = buildTree(database_result)
Nach dem Login kopieren

Die Baumvariable enthält jetzt ein verschachteltes Array, das die hierarchische Struktur von Seiten oder Kategorien darstellt.

Das obige ist der detaillierte Inhalt vonWie kann eine rekursive Funktion ein mehrdimensionales Array aus flachen Datenbankergebnissen erstellen?. 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