Поскольку вы знаете максимальные отношения, которые могут быть в иерархии,
Ниже будет представлен запрос -
hive> select * from hier;
OK
parent child child_desc
C1 C11 Party
C1 C111 Placement
C111 C1111 XM
C12 C121 Brand
C2 C12 Equity
XN12 C1 Private
XN12 C2 Public
Time taken: 0.123 seconds, Fetched: 7 row(s)
Запрос -
with lvl1 as
(
select p1.parent, p1.child child1, p1.child_desc child_desc1, p2.child child2, p2.child_desc child_desc2
from hier p1 left outer join hier p2
on p1.child = p2.parent
)
, lvl2 as
(
select lvl1.parent, lvl1.child1, lvl1.child_desc1, lvl1.child2 child2, lvl1.child_desc2, p3.parent p2,
p3.child as child3, p3.child_desc child_desc3
from lvl1 left outer join hier p3 on nvl(lvl1.child2,'A') = nvl(p3.parent,'A')
)
, lvl3 as
(
select lvl2.parent, lvl2.child1 child1, lvl2.child_desc1, lvl2.child2 child2, lvl2.child_desc2,
lvl2.child3 hild3, lvl2.child_desc3, p3.child as child4, p3.child as child_desc4
from lvl2 left outer join hier p3 on nvl(lvl2.child3,'A') = nvl(p3.parent,'A')
)
select * from lvl3;
C1 C11 Party NULL NULL NULL NULL NULL NULL
C1 C111 Placement C1111 XM NULL NULL NULL NULL
C111 C1111 XM NULL NULL NULL NULL NULL NULL
C12 C121 Brand NULL NULL NULL NULL NULL NULL
C2 C12 Equity C121 Brand NULL NULL NULL NULL
XN12 C1 Private C11 Party NULL NULL NULL NULL
XN12 C1 Private C111 Placement C1111 XM NULL NULL
XN12 C2 Public C12 Equity C121 Brand NULL NULL
Выше запросдля уровня 3 вы можете скопировать его на уровень 15.
Я проверил вышеупомянутый запрос для 3 уровней.
hive> select * from hier;
OK
parent child
C1 C11
C11 C12
C12 123
P1 C1
P2 C2
o / p -
C1 C11 C12 123 NULL
C11 C12 123 NULL NULL
C12 123 NULL NULL NULL
P1 C1 C11 C12 123
P2 C2 NULL NULL NULL
Если вам нужен запрос для n-уровней и вы не хотите жестко его кодировать, это потребует некоторых сценариев (с большим объемом работы) для создания запроса или повторения одного и того же запроса несколько раз.
Надеюсь, это поможет