oracle中的start with …… connect by 递归用法

来源:互联网 发布:mac系统导出照片 编辑:程序博客网 时间:2024/06/02 02:34


这个子句主要是用于B树结构类型的数据递归查询,给出B树结构类型中的任意一个结点,遍历其最终父结点或者子结点。

先看原始数据:

复制代码
 1 create table a_test 2 ( parentid varchar2(10), 3   subid    varchar2(10)); 4  5 insert into a_test values ( '1', '2' ); 6 insert into a_test values ( '1', '3' ); 7 insert into a_test values ( '2', '4' ); 8 insert into a_test values ( '2', '5' ); 9 insert into a_test values ( '3', '6' );10 insert into a_test values ( '3', '7' );11 insert into a_test values ( '5', '8' );12 insert into a_test values ( '5', '9' );13 insert into a_test values ( '7', '10' );14 insert into a_test values ( '7', '11' );15 insert into a_test values ( '10', '12' );16 insert into a_test values ( '10', '13' );17 18 commit;19 20 select * from a_test;
复制代码

 

对应B树结构为:

 


 

接下来看一个示例:

要求给出其中一个结点值,求其最终父结点。以7为例,看一下代码

start with 子句:遍历起始条件,有个小技巧,如果要查父结点,这里可以用子结点的列,反之亦然。

connect by 子句:连接条件。关键词prior,prior跟父节点列parentid放在一起,就是往父结点方向遍历;prior跟子结点列subid放在一起,则往叶子结点方向遍历,

                         parentid、subid两列谁放在“=”前都无所谓,关键是prior跟谁在一起。

order by 子句:排序,不用多说。

--------------------------------------------------

下面看看往叶子结点遍历的例子:

这里start with 子句用了parentid列,具体区别后面举例说明。

connect by 子句中,prior跟subid在同一边,就是往叶子结点方向遍历去了。因为7有两个子结点,所以第一级中有两个结果(10和11),10有两个子结点(12,13),11无,所以第二级也有两个结果(12,13)。即12,13就是叶子结点。

 





 

 

下面看下start with子句中选择不同的列的区别:

以查询叶子结点(往下遍历)为例

结果很明显,原意是要以7为父结点,遍历其子结点,左图取的是父结点列的值,结果符合原意;右图取的是子结点列的值,结果多余的显示了7 的父结点3.

---------------------------------------

关于where条件的语句,以后验证后再记录。先留个疑问

 

阅读全文
'); })();
0 0
原创粉丝点击
热门IT博客
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 二模四冲 二模 三模 双模 执业药师中药二模考实战卷二 第二次人生 第二次降准今落地 二次函数 二次人生 二次函数顶点坐标公式 二次抵押 二次元真理之门 二次元之真理之门 你们二次元真玩 二次元小女孩泳装凸现沟图片 我的二次元禽兽人生 崩溃二次元 崩溃的二次元 淑荣二次找老卫止痒 二次元的强推人生 我二次元禽兽人生 刘校长第二次玩梦莹 二次项定理 二次补眉后还会结痂吗 二次不等式 二次剖腹产会更痛吗 篮球二次 解一元二次方程 一元二次方程公式法 二次发育是什么意思 一次能源和二次能源 解二次不等式 初三一元二次方程 一元二次函数 一元二次方程实际问题 一元二次方程根的判别式 三次 thinkphp二次开发 二次三项式因式分解 二次函数知识点总结 二次函数解析式