当开发过程需要查询上下级机构类似的树形机构,还有就是查询当前等级下的所有所属节点

这个子句主要是用于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条件的语句,以后验证后再记录。先留个疑问

最新文章

  1. VS2015中SharedProject与可移植类库(PCL)项目
  2. [课程设计]任务进度条&开发日志目录
  3. Android ImageView的scaleType属性与adjustViewBounds属性(转载)
  4. Android-onTouchEvent方法的使用
  5. Context是什么,怎么用
  6. [转载] CMake Official Tutorial——教程还是官方的好
  7. WKWebView-b
  8. @property属性
  9. 用Python做2048游戏 网易云课堂配套实验课。通过GUI来体验编程的乐趣。
  10. qq面板/ 好友列表
  11. 微信客户端+微信公众平台+新浪云SAE+Arduino+WS100(控制LED)
  12. amaze UI 笔记 - JS
  13. HBase表创建、删除、清空
  14. 拥抱开源,Office 365开发迎来新时代
  15. blfs(systemv版本)学习笔记-wget的安装与配置
  16. SOA:A note on RPC
  17. windows下WAMP php5.x redis扩展
  18. PostgreSQL索引介绍
  19. [原][译][osg][osgEarth]飞行模拟软件JSBSim的操作(FGFCS类)
  20. HTML 视频(Videos)

热门文章

  1. Android Http请求头与响应头的学习
  2. Boot Sector - Hello world
  3. JAVA开发环境搭建 - Eclipse基本配置
  4. Xpath定位总结
  5. python学习笔记(一)元组tuple
  6. Gradle之恋-任务2
  7. Struts2框架(5)---result结果集
  8. ViewPager详解
  9. 使用webcollector爬虫技术获取网易云音乐全部歌曲
  10. 快速上手UIBezierPath