Heim >Datenbank >MySQL-Tutorial >Wie rufe ich alle Unterverzeichnisse eines bestimmten Verzeichnisses mit einer einzigen rekursiven SQL-Abfrage ab?

Wie rufe ich alle Unterverzeichnisse eines bestimmten Verzeichnisses mit einer einzigen rekursiven SQL-Abfrage ab?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2025-01-02 19:07:40257Durchsuche

How to Retrieve All Subdirectories of a Given Directory Using a Single Recursive SQL Query?

Rekursive Abfragen zum Abrufen von Unterverzeichnissen

Stellen Sie sich ein Szenario vor, in dem Sie eine Tabelle mit dem Namen „folders_table“ haben, die eine Verzeichnisstruktur mit Spalten für id_folder und id_folder_parent erfasst und Ordnername. Um alle Unterverzeichnisse eines bestimmten Verzeichnisses mit einer einzigen SELECT-Abfrage abzurufen, müssen Sie einen rekursiven Ansatz wählen. Die folgenden Schritte bieten Orientierung:

  1. Ändern Sie die Datenbankstruktur: Ändern Sie die Ordnertabelle so, dass sie eine Ebenenspalte enthält, die die Tiefe jedes Ordners innerhalb der Hierarchie angibt. Beginnen Sie mit Ebene 1 für das Stammverzeichnis und erhöhen Sie diese für jede Ebene darunter.
  2. Erstellen Sie eine rekursive Abfrage: Verwenden Sie einen rekursiven CTE (Common Table Expression), um die Verzeichnisstruktur zu durchlaufen. Die Abfrage sollte mit dem gewünschten Stammordner beginnen und alle seine Unterverzeichnisse, einschließlich ihrer Ebene, rekursiv abrufen.
  3. Filtern und Verknüpfen: Beschränken Sie die Abfrage darauf, nur die Unterverzeichnisse der gewünschten Tiefe einzubeziehen. Verknüpfen Sie es mit der ursprünglichen Ordnertabelle, um bei Bedarf zusätzliche Ordnerdetails abzurufen.

Mit diesem Ansatz können Sie mit einer einzigen Abfrage einen Baum von Unterverzeichnissen bis zu einer beliebigen Tiefe abrufen. Ausführliche Implementierungsrichtlinien finden Sie in den in der bereitgestellten Antwort bereitgestellten Ressourcen.

Das obige ist der detaillierte Inhalt vonWie rufe ich alle Unterverzeichnisse eines bestimmten Verzeichnisses mit einer einzigen rekursiven SQL-Abfrage ab?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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