Heim >Datenbank >MySQL-Tutorial >Wie kann ich mit einer einzigen Abfrage alle Vorfahren eines Knotens in einer hierarchischen MySQL-Tabelle finden?
Alle Eltern in einer MySQL-Tabelle mit einer einzigen Abfrage mithilfe eines rekursiven CTE finden
In einer Datenbank mit einer hierarchischen Struktur die Eltern identifizieren eines bestimmten Datensatzes kann eine komplexe Aufgabe sein. In MySQL kann diese Herausforderung mithilfe eines Recursive Common Table Expression (CTE) effizient angegangen werden. Lassen Sie uns die Problemstellung und ihre Lösung untersuchen.
Problemstellung:
Gegeben sei eine MySQL-Tabelle mit einer hierarchischen Struktur (wie die im bereitgestellten Schema), wo Jede Zeile stellt einen Knoten mit einer ID, einem Titel, einer übergeordneten ID und anderen relevanten Informationen dar. Die Aufgabe besteht darin, alle Vorfahren (übergeordneten Knoten) eines bestimmten Knotens in der Hierarchie mit einem einzigen abzurufen Abfrage.
Lösung:
Die bereitgestellte Lösung nutzt einen rekursiven CTE, um die Hierarchie zu durchqueren und die Eltern eines durch seine ID angegebenen Knotens zu identifizieren. Die folgende Abfrage veranschaulicht den Ansatz:
SELECT T2.id, T2.title, T2.controller, T2.method, T2.url FROM ( SELECT @r AS _id, (SELECT @r := parent_id FROM menu WHERE id = _id) AS parent_id, @l := @l + 1 AS lvl FROM (SELECT @r := 31, @l := 0) vars, menu m WHERE @r <> 0) T1 JOIN menu T2 ON T1._id = T2.id ORDER BY T1.lvl DESC;
Abfrageerklärung:
Diese Abfrage ruft effizient alle übergeordneten Knoten des angegebenen Knotens mit einer einzigen SQL-Anweisung ab und bietet so eine praktische und leistungsstarke Lösung für die Navigation hierarchischer Daten in MySQL.
Das obige ist der detaillierte Inhalt vonWie kann ich mit einer einzigen Abfrage alle Vorfahren eines Knotens in einer hierarchischen MySQL-Tabelle finden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!