Oracle树查询(start with connect by prior)探究
admin
2023-05-14 05:21:52
0

oracle树查询的最重要的语法结构是:select…start with…connect by…prior,通过该查询可以将表中的关系以树的形式展示出来。

1、创建测试表及数据:

--创建测试表

CREATE TABLE YAG_TREE(

     T_ID NUMBER(10) NOT NULL, --id

     T_CONTEXT VARCHAR2(20),   --内容

     PARENTID NUMBER(10)       --父 id

);

--创建序列

CREATE SEQUENCE SEQ_YAG START WITH 1 MAXVALUE 100 INCREMENT BY 1 NOCYCLE CACHE 10;

--生成父节点数据

BEGIN

  FOR I IN 1..5 LOOP

    INSERT INTO YAG_TREE VALUES(SEQ_YAG.NEXTVAL,'父节点'||SEQ_YAG.CURRVAL,NULL);

    COMMIT;

  END LOOP;    

END;

--生成一级节点数据

BEGIN

  FOR I IN 1..15 LOOP

    IF I <=3 THEN 

      INSERT INTO YAG_TREE VALUES(SEQ_YAG.NEXTVAL,'一级节点'||SEQ_YAG.CURRVAL,1);

    ELSIF I<=6 THEN

      INSERT INTO YAG_TREE VALUES(SEQ_YAG.NEXTVAL,'一级节点'||SEQ_YAG.CURRVAL,2);

    ELSIF I<=9 THEN

      INSERT INTO YAG_TREE VALUES(SEQ_YAG.NEXTVAL,'一级节点'||SEQ_YAG.CURRVAL,3);

    ELSIF I<=12 THEN

      INSERT INTO YAG_TREE VALUES(SEQ_YAG.NEXTVAL,'一级节点'||SEQ_YAG.CURRVAL,4);

    ELSIF I<=15 THEN

      INSERT INTO YAG_TREE VALUES(SEQ_YAG.NEXTVAL,'一级节点'||SEQ_YAG.CURRVAL,5);

    COMMIT;

    END IF;

  END LOOP;    

END;

--生成二级节点数据

BEGIN

  FOR I IN 1..15 LOOP

    INSERT INTO YAG_TREE VALUES(SEQ_YAG.NEXTVAL,'二级节点'||SEQ_YAG.CURRVAL,SEQ_YAG.CURRVAL-15);

    COMMIT;

  END LOOP;    

END;

2、树查询应用:

--树查询1:查询父节点id=1的下面所有子节点(即所有后代)

SELECT LEVEL /*树的深度*/,SYS_CONNECT_BY_PATH(T_CONTEXT, '--->') /*树的路径*/,A.*

  FROM YAG_TREE A

 START WITH T_ID = 1

CONNECT BY PRIOR T_ID = PARENTID;


LEVEL       SYS_CONNECT_BY_PATH           T_ID         T_CONTEXT         PARENTID

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

1        父节点                             11            父节点           1

2        父节点1--->一级节点                66           一级节点6         1

3        父节点1--->一级节点6--->二级节点21 21           二级节点21        6

2        父节点1--->一级节点7               7            一级节点7         1

3        父节点1--->一级节点7--->二级节点22 22           二级节点22        7

2        父节点1--->一级节点8               8            一级节点8         1

3        父节点1--->一级节点8--->二级节点23 23           二级节点23        8


--树查询2:查询某个节点的所有父节点(即所有先代)

SELECT * FROM YAG_TREE START WITH T_ID=26 CONNECT BY PRIOR PARENTID=T_ID;


    T_ID      T_CONTEXT           PARENTID

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

       26    二级节点26                11

       11    一级节点11                2

       2     父节点2   


<-------待续-------->

学习资源:http://www.cnblogs.com/linjiqin/archive/2013/06/24/3152674.html

相关内容

热门资讯

马尔代夫史上最严重单次潜水事故... 当地时间14日,在马尔代夫发生一起5名游客在潜水时全部身亡的惨剧。遇难者中包括一名大学教授和她的女儿...
180多万元莫名通过支付宝捐给... “关闭支付功能后 180多万元凌晨莫名通过支付宝捐给慈善机构”一事被曝光后,引发网友高度关注。5月1...
日本自卫队,该去捕熊了 当你清晨起床,看到一头陌生的黑熊正在敲你家的玻璃窗,是什么感觉?今年,日本的“熊灾”愈发厉害了。这些...
美团龙珠等入股AI软件开发商超... 天眼查App显示,近日,上海超维无际电子科技有限责任公司发生工商变更,新增北京龙珠股权投资基金合伙企...
苹果华为高端机降价 华为Pur... 5月15日,618大促前夕,华为苹果率先打响高端手机价格战,iPhone 17 Pro在京东、天猫、...
智启确山·AI赋能 确山县第七... 大象新闻记者 雷刚 通讯员 李闯志 纪兴红 为推进人工智能科普教育,点燃青少年科创梦想,2026年5...
社团焕彩逐光前行 科技赋能筑梦... 为进一步提升全区学校社团建设水平,搭建校际交流互鉴平台,5月12日,梁园区2026年中小学学生社团巡...
吃火锅、蒸桑拿、访企业,这位北... ·明凯,1966年出生,毕业于芬兰赫尔辛基大学政治史专业,2024年起出任芬兰驻华大使至今。当地时间...
除了大熊猫,这些外国市长还想从... 5月15日,成都飘起小雨。作为配套活动之一,2026成都国际友城合作与发展大会的嘉宾们走进成都大熊猫...
郑州新城建一期进入收尾阶段,C... 【大河财立方 记者 唐卫东】 随着第58个世界电信和信息社会日临近,郑州“新城建”试点项目迎来阶段性...