Учитывая следующую таблицу:
create table TreeNode
(
ID int not null primary key,
ParentID int null foreign key references TreeNode (ID)
)
Как я могу написать общее табличное выражение для начала в корне (WHERE ParentID IS NULL) и обходить его потомков, пока результирующий набор не содержит некоторый целевой узел (например, Где ID = n)?Легко начать с целевого узла и перейти вверх к корню, но это не сгенерирует тот же набор результатов.В частности, узлы, имеющие того же родителя, что и целевой узел, не будут включены.
Моя первая попытка была:
with Tree as
(
select
ID,
ParentID
from
TreeNode
where
ParentID is null
union all select
a.ID,
a.ParentID
from
TreeNode a
inner join Tree b
on b.ID = a.ParentID
where
not exists (select * from Tree where ID = @TargetID)
)
, которая выдает ошибку: Recursive member of a common table expression 'Tree' has multiple recursive references.
ПРИМЕЧАНИЕ : меня интересует только обход сверху вниз.