Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Abrufen aller untergeordneten Elemente (und ihrer untergeordneten Elemente) eines bestimmten übergeordneten Knotens in einer relationalen MySQL/MariaDB-Tabelle

Überprüfen Sie dies. Der in @pv :='6' angegebene Wert sollte auf die ID des Elternteils gesetzt werden, von dem Sie alle Nachkommen finden möchten.

Sie können auch die Demo aktualisiert live überprüfen

            select  Parent, concat ( "{" ,Parent,",",GROUP_CONCAT(concat (child )SEPARATOR ','),"}")   as Child
            from    (select * from #TableName
                     order by parent, child) s,
                    (select @pv := '6') initialisation
            where   find_in_set(parent, @pv) > 0
            and     @pv := concat(@pv, ',', child);

Um untergeordnete Elemente mit übergeordneten Elementen in einer Spalte anzuzeigen, verwenden Sie die folgende Abfrage:

            select parent as child from tchilds where parent = @pv2
            union
            select  Child
            from    (select * from tchilds
                     order by parent, child) s,
                    (select @pv2 := '6') initialisation
            where   find_in_set(parent, @pv2) > 0
            and     @pv2 := concat(@pv2,',', child)

Lassen Sie uns wissen, wenn Sie noch Fragen oder Bedenken haben.