oracle 的 start with ... connect by ...

语法:

   select * from some_table

                  [where 条件1]

                  connect by [条件2]

                  start with [条件3];   

其中 connect by 与 start with 语句摆放的先后顺序不影响查询的结果,[where 条件1]可以不需要。

 [where 条件1]、[条件2]、[条件3]各自作用的范围都不相同:     

 [where 条件1]

是在根据“connect by [条件2] start with [条件3]”选择出来的记录中进行过滤,是针对单条记录的过滤, 不会考虑树的结构(最后的过滤);

 [ connect by 条件2]

指定构造树的条件,以及对树分支的过滤条件,在这里执行的过滤会把符合条件的记录及其下的所有子节点都过滤掉;   

 [ start with 条件3]

限定作为搜索起始点的条件,如果是自上而下的搜索则是限定作为根节点的条件,如果是自下而上的搜索则是限定作为叶子节点的条件; 

要根据connect by 从上到下还是从下到上,来确定起始节点,可能是叶节点,也可能是父节点,这些开始节点可以是多个,并且包含这些节点。

 ==========================================================================

例子:

表结构:

-- Create table

create table A

(

  id NUMBER,

  name VARCHAR2(20),

  pid NUMBER

)

 

select * from A start with id=2 connect by prior id=pid;--从父到子(从上到下)
 
 
 
select * from A start with id=2 connect by prior pid= id; --从子到父  (从下到上)
 
 
select * from A start with id=2 connect by pid= id;   --不会进行循环

 

对prior的理解

1.prior可以不要,不要的时候只能查找到符合“start with [条件3]”的记录,不会在寻找这些记录的子节点或父节点。

2.

 connect by prior id=pid  采用自上而下的搜索方式(先找父节点然后找子节点)

 connect by id=prior pid采用自下而上的搜索方式(先找叶子节点然后找父节点)

 

从子节点到父节点,则prior指的是子节点,构造出从子节点到父节点的关系,即子节点的pid=父节点的id (prior pid=id) ;从父节点到子节点,则prior指的是父节点,构造出从父节点到子节点的关系,即父节点的id=子节点的pid(proid id =pid)。

3.prior id=pid 和 pid=prior id  效果是一样的。

posted @ 2014-12-26 15:59  lion85  阅读(1213)  评论(0编辑  收藏  举报