gpt4 book ai didi

oracle - 从具有级别的 Oracle 表中获取父项

转载 作者:行者123 更新时间:2023-12-02 03:01:25 25 4
gpt4 key购买 nike

我有一些有序和分级的分层数据,但父/子关系没有明确定义。

ORD     ID     LVL
0 ABC 1
1 DEF 1
2 EFG 2
.. .. 3
.. .. 3
.. .. 2
.. .. 2
.. .. 1

我想做的是计算每一行的父 ID,如下所示:

ORD     ID     LVL     PARENT
0 ABC 1 ABC
1 DEF 1 DEF
2 EFG 2 DEF
.. HIJ 3 EFG
.. KLM 3 EFG
.. NOP 2 DEF
.. QRS 2 DEF
.. TUV 1 TUV

我一直在摸索 case 语句和 LAST_VALUE,但我现在求助于这里。我想如果我能弄清楚父 ID,我就可以使用 oracle 的分层函数对数据求和,但现在这对我来说只是一个平面表。

我该怎么做?

编辑:这是一个更好的数据样本。 ORD 是独特的且不断增加的,但它会重置每个模型。我认为这是导致我的问题的原因..

ORD ID      LVL
0 W7957 01
1 29813 01
2 37830 01
3 42986 01
4 C8746 02
5 V1970 02
6 P7958 03
7 P8500 03
8 V2405 03
9 F3400 03
10 E3366 02
11 M2894 03
12 53928 03
13 22480 03
14 27120 02
15 18159 02
16 T4193 03
17 X7371 03
18 X8257 03

最终决定 - 这行得通。我不得不使用 rownum 而不是 ORD 并按 MODEL_NAME 和 ORD 排序,但解决方案有效。非常感谢您的帮助!

最佳答案

如果 ORD 是唯一的并且连续增加,例如这样:

select * from table555;

ORD ID LVL PAR
---------- --- ---------- ---
0 ABC 1 ABC
1 DEF 1 DEF
2 EFG 2 DEF
3 HIJ 3 EFG
4 KLM 3 EFG
5 NOP 2 DEF
6 QRS 2 DEF
7 TUV 1 TUV

然后在 Oracle12c 上你可以使用这个查询:

select t.* ,
nvl(
( select id from table555 t1
where t1.lvl < t.lvl
and t1.ord < t.ord
order by ord desc
fetch first row only
)
,
id ) As my_par
from table555 t
;

ORD ID LVL PAR MY_
---------- --- ---------- --- ---
0 ABC 1 ABC ABC
1 DEF 1 DEF DEF
2 EFG 2 DEF DEF
3 HIJ 3 EFG EFG
4 KLM 3 EFG EFG
5 NOP 2 DEF DEF
6 QRS 2 DEF DEF
7 TUV 1 TUV TUV

在早期版本中,您可以使用两个子查询:

select  ORD,ID,LVL,PARENT,
(SELECT id FROM table555 t1
WHERE t1.ord = t.max_ord
) as my_parent
FROM (
select t.*,
nvl(
(select max( ord )
from table555 t1
where t1.lvl < t.lvl
and t1.ord < t.ord
),
ord
)as max_ord
from table555 t
) t
;

ORD ID LVL PAR MY_
---------- --- ---------- --- ---
0 ABC 1 ABC ABC
1 DEF 1 DEF DEF
2 EFG 2 DEF DEF
3 HIJ 3 EFG EFG
4 KLM 3 EFG EFG
5 NOP 2 DEF DEF
6 QRS 2 DEF DEF
7 TUV 1 TUV TUV

关于oracle - 从具有级别的 Oracle 表中获取父项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45966712/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com