我正在试图检索每个子代的列表和每一项。我不确定我是否说得通,我会尽力解释的。
示例数据:
ID | PID
--------
1 | 0
2 | 1
3 | 1
4 | 1
5 | 2
6 | 2
7 | 5
8 | 3等等。
预期的结果是:
ID | Decendant
--------------
1 | 1
1 | 2
1 | 3
1 | 4
...
2 | 2
2 | 5
2 | 6
2 | 7
3 | 3
3 | 8等等。
通过使用光标移动数据并将每个子代插入到表中,然后从它们中进行选择,目前正在实现这一目标。
我想知道是否有更好的方法来实现这些,必须有一种方法来纠正一个查询,从而返回所需的结果。
如果有人有想法,或已经解决了这一点之前,它将是非常感谢。排序不重要,1-1,2-2引用也不重要.拥有它将是很酷的,但并不重要。
发布于 2014-02-06 08:42:23
select connect_by_root(id) as ID, id as Decendant
from table1
connect by prior id = pid
order by 1, 2小提琴
发布于 2014-02-06 08:56:29
这是我的尝试!不确定,如果我把你弄对了!
select pid ,connect_By_root(id) as descendant from process
connect by id = prior pid
union all
select distinct pid,pid from
process
order by pid,descendanthttps://stackoverflow.com/questions/21597357
复制相似问题