首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Oracle层次查询连接以选择所有附加项

Oracle层次查询连接以选择所有附加项
EN

Stack Overflow用户
提问于 2014-02-06 08:13:10
回答 2查看 102关注 0票数 0

我正在试图检索每个子代的列表和每一项。我不确定我是否说得通,我会尽力解释的。

示例数据:

代码语言:javascript
复制
ID | PID
--------
1  | 0
2  | 1
3  | 1
4  | 1
5  | 2
6  | 2
7  | 5
8  | 3

等等。

预期的结果是:

代码语言:javascript
复制
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引用也不重要.拥有它将是很酷的,但并不重要。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-02-06 08:42:23

代码语言:javascript
复制
select connect_by_root(id) as ID, id as Decendant
from table1
connect by prior id = pid
order by 1, 2

小提琴

票数 1
EN

Stack Overflow用户

发布于 2014-02-06 08:56:29

这是我的尝试!不确定,如果我把你弄对了!

代码语言:javascript
复制
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,descendant
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21597357

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档