Oracle 9i判断是叶子或根节点,是比较麻烦的一件事情,SQL演示脚本如下:

  1. DROP TABLE idb_hierarchical;
  2. create TABLE idb_hierarchical
  3. (
  4. id number,
  5. parent_id number,
  6. str varchar2(10)
  7. );
  8. insert into idb_hierarchical values(1,null,'A');
  9. insert into idb_hierarchical values(2,1,'B');
  10. insert into idb_hierarchical values(3,2,'C');
  11. insert into idb_hierarchical values(4,3,'D');
  12. insert into idb_hierarchical values(5,2,'E');
  13. insert into idb_hierarchical values(6,2,'F');
  14. insert into idb_hierarchical values(7,3,'G');
  15. insert into idb_hierarchical values(8,4,'H');
  16. insert into idb_hierarchical values(9,4,'I');
  17. insert into idb_hierarchical values(10,null,'J');
  18. insert into idb_hierarchical values(11,10,'K');
  19. insert into idb_hierarchical values(12,11,'L');
  20. insert into idb_hierarchical values(13,10,'M');
  1. DROP TABLE idb_hierarchical;
  2. create TABLE idb_hierarchical
  3. (
  4. id number,
  5. parent_id number,
  6. str varchar2(10)
  7. );
  8. insert into idb_hierarchical values(1,null,'A');
  9. insert into idb_hierarchical values(2,1,'B');
  10. insert into idb_hierarchical values(3,2,'C');
  11. insert into idb_hierarchical values(4,3,'D');
  12. insert into idb_hierarchical values(5,2,'E');
  13. insert into idb_hierarchical values(6,2,'F');
  14. insert into idb_hierarchical values(7,3,'G');
  15. insert into idb_hierarchical values(8,4,'H');
  16. insert into idb_hierarchical values(9,4,'I');
  17. insert into idb_hierarchical values(10,null,'J');
  18. insert into idb_hierarchical values(11,10,'K');
  19. insert into idb_hierarchical values(12,11,'L');
  20. insert into idb_hierarchical values(13,10,'M');

示例数据清单如下:

  1. SELECT RPAD('+',LEVEL*2+1,'.')||STR STR_LEVEL,ID,PARENT_ID,LEVEL LVL
  2. FROM idb_hierarchical
  3. START WITH PARENT_ID IS NULL
  4. CONNECT BY PARENT_ID = PRIOR ID;
  1. SELECT RPAD('+',LEVEL*2+1,'.')||STR STR_LEVEL,ID,PARENT_ID,LEVEL LVL
  2. FROM idb_hierarchical
  3. START WITH PARENT_ID IS NULL
  4. CONNECT BY PARENT_ID = PRIOR ID;
表1:数据清单
STR_LEVEL ID PARENT_ID LVL
+..A 1   1
+….B 2 1 2
+……C 3 2 3
+……..D 4 3 4
+……….H 8 4 5
+……….I 9 4 5
+……..G 7 3 4
+……E 5 2 3
+……F 6 2 3
+..J 10   1
+….K 11 10 2
+……L 12 11 3
+….M 13 10 2

在表1中,ID为8、9、 7、5、6、12、13都没有子节点,因此称为叶节点。

1.oracle9i 查询叶节点

只显示叶子节点SQL

  1. SELECT RPAD('+',LEVEL*2+1,'.')||STR STR_LEVEL,ID,PARENT_ID,LEVEL LVL
  2. FROM idb_hierarchical I
  3. --在oracle 9i中显示叶节点,需要判断是否有子节点即可
  4. WHERE NOT EXISTS(SELECT 1
  5. FROM idb_hierarchical B
  6. WHERE I.ID=B.PARENT_ID)
  7. START WITH PARENT_ID IS NULL
  8. CONNECT BY PARENT_ID = PRIOR ID;
  1. SELECT RPAD('+',LEVEL*2+1,'.')||STR STR_LEVEL,ID,PARENT_ID,LEVEL LVL
  2. FROM idb_hierarchical I
  3. --在oracle 9i中显示叶节点,需要判断是否有子节点即可
  4. WHERE NOT EXISTS(SELECT 1
  5. FROM idb_hierarchical B
  6. WHERE I.ID=B.PARENT_ID)
  7. START WITH PARENT_ID IS NULL
  8. CONNECT BY PARENT_ID = PRIOR ID;
表2
STR_LEVEL ID PARENT_ID LVL
+……….H 8 4 5
+……….I 9 4 5
+……..G 7 3 4
+……E 5 2 3
+……F 6 2 3
+……L 12 11 3
+….M 13 10 2

显示所有节点,标明该行是否为叶节点SQL

  1. SELECT RPAD('+',LEVEL*2+1,'.')||STR STR_LEVEL,ID,PARENT_ID,LEVEL LVL,
  2. NVL((SELECT 'N'
  3. FROM idb_hierarchical B
  4. WHERE I.ID=B.PARENT_ID
  5. AND ROWNUM  < 2),'Y') IS_LEAF
  6. FROM idb_hierarchical I
  7. START WITH PARENT_ID IS NULL
  8. CONNECT BY PARENT_ID = PRIOR ID;
  1. SELECT RPAD('+',LEVEL*2+1,'.')||STR STR_LEVEL,ID,PARENT_ID,LEVEL LVL,
  2. NVL((SELECT 'N'
  3. FROM idb_hierarchical B
  4. WHERE I.ID=B.PARENT_ID
  5. AND ROWNUM  < 2),'Y') IS_LEAF
  6. FROM idb_hierarchical I
  7. START WITH PARENT_ID IS NULL
  8. CONNECT BY PARENT_ID = PRIOR ID;
表3
STR_LEVEL ID PARENT_ID LVL IS_LEAF
+..A 1   1 N
+....B 2 1 2 N
+......C 3 2 3 N
+........D 4 3 4 N
+..........H 8 4 5 Y
+..........I 9 4 5 Y
+........G 7 3 4 Y
+......E 5 2 3 Y
+......F 6 2 3 Y
+..J 10   1 N
+....K 11 10 2 N
+......L 12 11 3 Y
+....M 13 10 2 Y

oracle 9i 查询根节点

  1. SELECT RPAD('+',LEVEL*2+1,'.')||STR STR_LEVEL,ID,PARENT_ID,LEVEL LVL
  2. FROM idb_hierarchical I
  3. START WITH id =2
  4. CONNECT BY PARENT_ID = PRIOR ID;
  1. SELECT RPAD('+',LEVEL*2+1,'.')||STR STR_LEVEL,ID,PARENT_ID,LEVEL LVL
  2. FROM idb_hierarchical I
  3. START WITH id =2
  4. CONNECT BY PARENT_ID = PRIOR ID;
表4
STR_LEVEL ID PARENT_ID LVL
+..B 2 1 1
+....C 3 2 2
+......D 4 3 3
+........H 8 4 4
+........I 9 4 4
+......G 7 3 3
+....E 5 2 2
+....F 6 2 2

根节点ID应该为3、5、6,即lvl为1即可

查询根节点,只显示根节点SQL

  1. SELECT RPAD('+', LEVEL * 2 + 1, '.') || STR STR_LEVEL,
  2. ID,
  3. PARENT_ID,
  4. LEVEL LVL,
  5. (select b.str
  6. from idb_hierarchical b
  7. where level = 1
  8. start with b.id = 2
  9. connect by prior b.id =  b.parent_id
  10. ) root_str
  11. FROM idb_hierarchical I
  12. where level = 1
  13. START WITH id = 2
  14. CONNECT BY PARENT_ID = PRIOR ID;
  1. SELECT RPAD('+', LEVEL * 2 + 1, '.') || STR STR_LEVEL,
  2. ID,
  3. PARENT_ID,
  4. LEVEL LVL,
  5. (select b.str
  6. from idb_hierarchical b
  7. where level = 1
  8. start with b.id = 2
  9. connect by prior b.id =  b.parent_id
  10. ) root_str
  11. FROM idb_hierarchical I
  12. where level = 1
  13. START WITH id = 2
  14. CONNECT BY PARENT_ID = PRIOR ID;
表5
STR_LEVEL ID PARENT_ID LVL ROOT_STR
+..B 2 1 1 B

标明根节点SQL

  1. SELECT RPAD('+', LEVEL * 2 + 1, '.') || STR STR_LEVEL,
  2. ID,
  3. PARENT_ID,
  4. DECODE(LEVEL, 1, 'Y', 'N') is_root,
  5. LEVEL LVL,
  6. (select b.str
  7. from idb_hierarchical b
  8. where level = 1
  9. start with b.id = 2
  10. connect by prior b.id = b.parent_id) root_str
  11. FROM idb_hierarchical I
  12. START WITH id = 2
  13. CONNECT BY PARENT_ID = PRIOR ID;
  1. SELECT RPAD('+', LEVEL * 2 + 1, '.') || STR STR_LEVEL,
  2. ID,
  3. PARENT_ID,
  4. DECODE(LEVEL, 1, 'Y', 'N') is_root,
  5. LEVEL LVL,
  6. (select b.str
  7. from idb_hierarchical b
  8. where level = 1
  9. start with b.id = 2
  10. connect by prior b.id = b.parent_id) root_str
  11. FROM idb_hierarchical I
  12. START WITH id = 2
  13. CONNECT BY PARENT_ID = PRIOR ID;
表6
STR_LEVEL ID PARENT_ID IS_ROOT LVL ROOT_STR
+..B 2 1 Y 1 B
+....C 3 2 N 2 B
+......D 4 3 N 3 B
+........H 8 4 N 4 B
+........I 9 4 N 4 B
+......G 7 3 N 3 B
+....E 5 2 N 2 B
+....F 6 2 N 2 B

在oracle 10g提供了connect_by_isleaf和connect_by_root

oracle 10g用connect_by_isleaf判断叶节点

  1. SELECT RPAD('+',LEVEL*2+1,'.')||STR STR_LEVEL,ID,PARENT_ID,LEVEL LVL
  2. FROM idb_hierarchical I
  3. where connect_by_isleaf=1
  4. START WITH PARENT_ID IS NULL
  5. CONNECT BY PARENT_ID = PRIOR ID;
  1. SELECT RPAD('+',LEVEL*2+1,'.')||STR STR_LEVEL,ID,PARENT_ID,LEVEL LVL
  2. FROM idb_hierarchical I
  3. where connect_by_isleaf=1
  4. START WITH PARENT_ID IS NULL
  5. CONNECT BY PARENT_ID = PRIOR ID;
表7
STR_LEVEL ID PARENT_ID LVL
+..........H 8 4 5
+..........I 9 4 5
+........G 7 3 4
+......E 5 2 3
+......F 6 2 3
+......L 12 11 3
+....M 13 10 2
  1. SELECT RPAD('+',LEVEL*2+1,'.')||STR STR_LEVEL,ID,PARENT_ID,LEVEL LVL,
  2. decode(connect_by_isleaf,1,'Y','N') IS_LEAF
  3. FROM idb_hierarchical I
  4. START WITH PARENT_ID IS NULL
  5. CONNECT BY PARENT_ID = PRIOR ID;
  1. SELECT RPAD('+',LEVEL*2+1,'.')||STR STR_LEVEL,ID,PARENT_ID,LEVEL LVL,
  2. decode(connect_by_isleaf,1,'Y','N') IS_LEAF
  3. FROM idb_hierarchical I
  4. START WITH PARENT_ID IS NULL
  5. CONNECT BY PARENT_ID = PRIOR ID;
表8
STR_LEVEL ID PARENT_ID LVL IS_LEAF
+..A 1   1 N
+....B 2 1 2 N
+......C 3 2 3 N
+........D 4 3 4 N
+..........H 8 4 5 Y
+..........I 9 4 5 Y
+........G 7 3 4 Y
+......E 5 2 3 Y
+......F 6 2 3 Y
+..J 10   1 N
+....K 11 10 2 N
+......L 12 11 3 Y
+....M 13 10 2 Y

oracle 10g用connect_by_root判断根节点

  1. SELECT RPAD('+', LEVEL * 2 + 1, '.') || STR STR_LEVEL,
  2. ID,
  3. PARENT_ID,
  4. LEVEL LVL,
  5. connect_by_root STR ROOT_STR
  6. FROM idb_hierarchical I
  7. START WITH id = 2
  8. CONNECT BY PARENT_ID = PRIOR ID;
  1. SELECT RPAD('+', LEVEL * 2 + 1, '.') || STR STR_LEVEL,
  2. ID,
  3. PARENT_ID,
  4. LEVEL LVL,
  5. connect_by_root STR ROOT_STR
  6. FROM idb_hierarchical I
  7. START WITH id = 2
  8. CONNECT BY PARENT_ID = PRIOR ID;
表9
STR_LEVEL ID PARENT_ID LVL ROOT_STR
+..B 2 1 1 B
+....C 3 2 2 B
+......D 4 3 3 B
+........H 8 4 4 B
+........I 9 4 4 B
+......G 7 3 3 B
+....E 5 2 2 B
+....F 6 2 2 B
  1. SELECT RPAD('+', LEVEL * 2 + 1, '.') || STR STR_LEVEL,
  2. ID,
  3. PARENT_ID,
  4. DECODE(LEVEL, 1, 'Y', 'N') is_root,
  5. LEVEL LVL,
  6. connect_by_root STR ROOT_STR
  7. FROM idb_hierarchical I
  8. START WITH id = 3
  9. CONNECT BY PARENT_ID = PRIOR ID;
  1. SELECT RPAD('+', LEVEL * 2 + 1, '.') || STR STR_LEVEL,
  2. ID,
  3. PARENT_ID,
  4. DECODE(LEVEL, 1, 'Y', 'N') is_root,
  5. LEVEL LVL,
  6. connect_by_root STR ROOT_STR
  7. FROM idb_hierarchical I
  8. START WITH id = 3
  9. CONNECT BY PARENT_ID = PRIOR ID;
表10
STR_LEVEL ID PARENT_ID IS_ROOT LVL ROOT_STR
+..C 3 2 Y 1 C
+....D 4 3 N 2 C
+......H 8 4 N 3 C
+......I 9 4 N 3 C
+....G 7 3 N 2 C
  1. SELECT RPAD('+', LEVEL * 2 + 1, '.') || STR STR_LEVEL,
  2. ID,
  3. PARENT_ID,
  4. DECODE(LEVEL, 1, 'Y', 'N') is_root,
  5. LEVEL LVL,
  6. connect_by_root STR ROOT_STR
  7. FROM idb_hierarchical I
  8. START WITH PARENT_ID = 2
  9. CONNECT BY PARENT_ID = PRIOR ID;
  1. SELECT RPAD('+', LEVEL * 2 + 1, '.') || STR STR_LEVEL,
  2. ID,
  3. PARENT_ID,
  4. DECODE(LEVEL, 1, 'Y', 'N') is_root,
  5. LEVEL LVL,
  6. connect_by_root STR ROOT_STR
  7. FROM idb_hierarchical I
  8. START WITH PARENT_ID = 2
  9. CONNECT BY PARENT_ID = PRIOR ID;
表11
STR_LEVEL ID PARENT_ID IS_ROOT LVL ROOT_STR
+..C 3 2 Y 1 C
+....D 4 3 N 2 C
+......H 8 4 N 3 C
+......I 9 4 N 3 C
+....G 7 3 N 2 C
+..E 5 2 Y 1 E
+..F 6 2 Y 1 F

【转】 oracle 层次查询判断叶子和根节点的更多相关文章

  1. Oracle 层次查询 connect by

      oracle 层次查询 语法:       SELECT ... FROM            [WHERE condition]                             --过 ...

  2. 带您了解Oracle层次查询

    http://database.51cto.com/art/201010/231539.htm Oracle层次查询(connect by )是结构化查询中用到的,下面就为您介绍Oracle层次查询的 ...

  3. Oracle层次查询

    Oracle层次查询的语法如下: 下面根据两道“烧脑”的题具体来体现: 1. 根据时间先后顺序,十二星座的英文名称用逗号串起来为'Aries,Taurus,Gemini,Cancer,Leo,Virg ...

  4. Oracle - 层次查询

    如果表中含有层次数据,可以通过使用层次查询有序地查看层次数据. 语法: condition:指一个或多个表达式和逻辑(布尔)运算符的组合,并返回TRUE.FALSE或UNKNOWNstart with ...

  5. Oracle层次查询start with connect by

    博客参考:https://www.cnblogs.com/jerryxing/articles/2339352.html start with connect by 层次查询(Hierarchical ...

  6. 【转载】Oracle层次查询和分析函数

    摘要 一组连续的数,去掉中间一些数,如何求出剩下的数的区间(即号段)?知道号段的起止,如何求出该号段内所有的数?知道一个大的号段范围和已经取过的号段,如何求出可用的号段?利用Oracle提供的强大的查 ...

  7. Oracle层次查询和分析函数在号段选取中的应用

    转自:http://www.itpub.net/thread-719692-1-1.html 摘要一组连续的数,去掉中间一些数,如何求出剩下的数的区间(即号段)?知道号段的起止,如何求出该号段内所有的 ...

  8. oracle层次查询的陷阱

    今天开发组同事找到我,说一个简单的层次查询非常慢,业务就是有一个存设备表连接关系的表,从node1连入,从node2连出,现在要找出node2的连出顺序,sql类似于: SELECT LEVEL ID ...

  9. Oracle层次查询和with函数的使用

    开发中大家应该都做过什么类似部门管理这样的功能,一般情况下一个部门下面还有下一级部门(子部门),这个层级就类似一棵树.这种情况下一般会把父级部门和子级部门分成2个或者多个表,这种算是比较常规的做法:有 ...

随机推荐

  1. oracle下导出某用户所有表的方法

    oracle下导出某用户所有表的方法 scott/tiger是用户名和密码,handson是导出的实例名 按用户方式导出数据(owner当中写的是用户名) exp scott/tiger@handso ...

  2. 轻量级验证码生成插件webutil-licenseImage源码与实例应用

    webutil-licenseImage 插件内置4种验证码样式,支持用户扩展.自定义样式实现简单验证码. 源码脱管地址: http://code.google.com/p/licenseimage/ ...

  3. vuex 温故而知新 mapState的使用

    虽然早就知道 mapState 的存在,但还是极少使用.最近代码的computed变多才开始意识到好处. 原来的代码: computed: { findLastSixMonthAir () { ret ...

  4. 转 Kubernetes 入门 概念理解

    你闺女也能看懂的插画版Kubernetes指南 原创  2016-06-30 作者 周小璐 译 编者按:Matt Butcher是Deis的平台架构师,热爱哲学,咖啡和精雕细琢的代码.有一天女儿走进书 ...

  5. ganglia安装 by frank

    作者是frank. 1.安装epelrpm -Uvh http://dl.fedoraproject.org/pub/epel/5/i386/epel-release-5-4.noarch.rpm2. ...

  6. 交叉验证(CrossValidation)方法思想简介[zz]

    以下简称交叉验证(Cross Validation)为CV.CV是用来验证分类器的性能一种统计分析方法,基本思想是把在某种意义下将原始数据(dataset)进行分组,一部分做为训练集(train se ...

  7. 【Android API】Android 4.1 API官方文档详解

    原文:http://android.eoe.cn/topic/summary 翻译:[eoeAndroid原创团队]kris.流风而逝.贼寇在何方.snowxwyo.lsy4833406 更新日期:2 ...

  8. Android-Cannot merge new index 66195 into a non-jumbo instruction的解决办法

    转载请注明来源:http://blog.csdn.net/goldenfish1919/article/details/33729679 用eclispe打包的时候报错: [2014-06-23 13 ...

  9. Android Eclipse Libs 的 jar 源码查看 (或者新版本ADT无法查看jar的源码)

    问题背景:在使用比较新的ADT的时候,无法导入Jar中的源码包查看源码.只好自己打开压缩包,实在恼火.在半年前,只好这样. 问题解决方案:我就以 " android-support-v4.j ...

  10. go 从入门到精通(二)基本数据类型和操作符

    一.文件名&关键字&标识符 所有go源码都是以.go结尾 标识符以字母或下划线开头,大小写敏感 下划线_是特殊标识符,用户忽略结果 保留关键字 导入包时可以设置别名 下面是保留关键字: ...