Chek this. Значение, указанное в @pv: = '6', должно быть установлено на идентификатор родителя, который вы хотите найти всех его потомков.
также вы можете проверить живой Demo updated
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);
Выход: {6,7,9,10}
Для отображения Чайлдс с родителем в одно использование столбца ниже запроса:
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)
Выход
дайте нам знать, если у вас есть еще какие вопросы или проблемы.
MySQL не поддерживает рекурсивные запросы, что идеально подходит для такого рода проблем. Сколько уровней глубины может быть деревом, и является ли эта максимальная глубина фиксированной? –
не зафиксировано глубиной, но я думаю, что не более 6 уровней глубины. Печально слышать, что MySQL не поддерживает рекурсивные запросы D :! – candlejack
Вы можете сделать самостоятельное присоединение 5 раз, если это будет приемлемо для вас. –