Я нашел решение для Oracle, использующее UNION ALL для двух иерархических запросов CONNECT BY, один из которых выбирает предков, а другой дочерних.
Я хочу добиться того же для обоих DB2 и SQL Server .
Я знаю один элемент, это может быть корень, ветвь или лист в иерархии.Мне нужно получить всю его иерархию.
Предположим, у меня есть itemid = 'item3' и class = 'my class' , мне нужно найти его предков и детей, я придумал:
with ancestor (class, itemid, parent, base, depth)
as (
select root.class, root.itemid, root.parent, root.itemid, 0
from item root
where root.class = 'myclass'
and root.itemid = 'item3'
-- union all
-- select child.class, child.itemid, child.parent, root.base, root.depth+1
-- from ancestor root, item child
-- where child.class = root.class
-- and child.parent = root.itemid
union all
select parent.class, parent.itemid, parent.parent, parent.itemid, root.depth-1
from ancestor root, item parent
where parent.class = root.class
and parent.itemid = root.parent
)
select distinct class, itemid, parent, base, depth
from ancestor
order by class, base, depth asc, itemid
Я хочу получить результат, подобный следующему:
class itemid parent base depth
myclass item1 null item3 -2
myclass item2 item1 item3 -1
myclass item3 item2 item3 0
myclass item4 item3 item3 1
myclass item5 item5 item3 2
Если запущенный выше SQL выполняется, я получаю штраф с предками.Теперь, если я удаляю комментарии, кажется, что это бесконечный цикл.Должен быть способ заставить это работать.
Я могу получить результаты в иерархии в одном направлении (предок или потомки), но я не могу получить оба по одному запросу.
Кто-нибудь когда-нибудь пробовалчто-то вроде того?
Спасибо