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

先看原始数据:

 1 create table a_test2 ( 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条件的语句,以后验证后再记录。先留个疑问

转自:https://www.cnblogs.com/benbenduo/p/4588612.html

oracle递归查询用法相关推荐

  1. ORACLE ROWNUM用法、select into与insert into区别、merge into的使用、递归查询

    ROWNUM用法 ORACLE 中ROWNUM用法总结! 对于 Oracle 的 rownum 问题,很多资料都说不支持>,>=,=,between...and,只能用以上符号(<. ...

  2. oracle递归查询指定子节点,oracle递归查询子节点

    通过子节点向根节点追朔. select * from persons.dept start with deptid=76 connect by prior paredeptid=deptid 通过根节 ...

  3. sql oracle 递归查询语句,oracle递归函数 oracle中SQL递归查询

    关于oracle递归调用的自定义函数如何结束 比如存储过程a中有b,b中含a.用return结束判断,执行还是锁表,怎么解决 关于oracle递归调用的自定义函数如何结束 可以调用. C语言最基本的模 ...

  4. oracle @spool,Oracle spool 用法小结

    Oracle spool 用法小结 转自:http://wallimn.javaeye.com/blog/472182 对于SPOOL 数据的SQL,最好要自己定义格式,以方便程序直接导入,SQL语句 ...

  5. oracle nvl用法

      oracle nvl用法 通过查询获得某个字段的合计值,如果这个值位null将给出一个预设的默认值 select nvl(sum(t.dwxhl),1) from tb_jhde t where ...

  6. with as 用法 oracle,with.as oracle的用法

    -----*************************with..as oracle的用法 --语法: with tempName as (select ....) select ... --例 ...

  7. Oracle递归查询示例分析

    Oracle递归查询示例分析 start with connect by 层次查询(Hierarchical Queries) 从顶级向下级查询 Select  a.areaid,a.name,a.p ...

  8. Oracle数据库用法汇总

    一些Oracle数据库用法的小总结 1.使用insert into创建新表 insert into destdb.sub_contract (userid,contractid) select msi ...

  9. [转载]Oracle触发器用法实例详解

    本文实例讲述了Oracle触发器用法.分享给大家供大家参考,具体如下: 一.触发器简介 触发器的定义就是说某个条件成立的时候,触发器里面所定义的语句就会被自动的执行. 因此触发器不需要人为的去调用,也 ...

最新文章

  1. 杭电acm2151题java的解法,杭电ACM题型分类
  2. Stone Game
  3. Scrum Guides 2017年最新修改
  4. selinux= 为 disabled_CentOS7关闭防火墙和SELinux
  5. mysql 语法错误检查,解决引号的使用错误1064(42000):SQL语法有错误;检查与您的MySQL服务器版本相对应的手册以使用正确的语法?...
  6. android 常用adb 及linux 命令
  7. POI中sheet.getRow方法返回值NullPointException
  8. 推荐一本学javascript的书籍---经典
  9. 【OpenCV入门指南】第二篇 缩放图像
  10. TypeScript:函数基础
  11. cad如何生成kml文件_如何制作KML文件?
  12. Edge浏览器安装Tampermonkey插件
  13. 51单片机-直流电机
  14. 自定义形状下载连接 ps资源
  15. jupyter notebook报错500 : Internal Server Error
  16. Linux查询ip地址ens33没有inet这个属性
  17. internal, switching, leakage power区别
  18. Specified class is an interface
  19. MacOS 利用keka.app压缩工具制作dmg文件
  20. 联想电脑如何修复计算机系统,Lenovo电脑如何用已备份的系统进行一键恢复

热门文章

  1. 计算机弹音乐薛之谦的歌曲,薛之谦 万能音符(The Key) 薛之谦歌曲,薛之谦mp3在线试听 - 5nd音乐网...
  2. zabbix 监控-华为路由器(ASG2100)
  3. 高速公路ETC卡签之我见1-概述
  4. 鹿晓亮:基于大数据云计算的语音识别深度平台
  5. 李宏毅机器学习 之 回归Regression(二)
  6. 激活 visio Premium 2010 vol 版本
  7. ∵∵∵∵不开心∵∵∵∵
  8. JS生成随机颜色(rgb)
  9. 【转载】吉安,被遗忘的才子之乡
  10. 手把手教程9-2: 460使用Flash模拟EEPROM