语法:connect by 是结构化查询中用到的,其基本语法如下:

start with,connect by主要目的:从表中取出树状数据。可以假想成表中存成的各条数据是分别是树中的一个结点。

select … from tablename start with 条件1
connect by prior 条件2
where 条件3;
其中:
条件1 是根结点限定语句,当然也可以放宽限定条件取多个结点,就形成多根树。
条件2 是连接条件。
条件3 是过滤条件,用于所返回的所有记录进行过滤。
 
例如
select * from table
start with id = ‘G113’
connect by prior id = pid
where fflag = ‘Y’;
 
在一个树状存储表中有两个字段,id和pid。其中pid为id上级记录的id。
用上述语法的查询可以取得这棵树的所有记录。
 
扫描顺序:
1,从根结点开始;
2,访问该结点;
3,判断该结点有无被访问的子结点,若有,则转向它的最左侧的的未访问的子结点,并执行第二步,否则执行第四步;
4,若该结点为根节点,则访问完毕,否则执行第五步;
5,返回该结点的父结点,并执行第三步;
 
 
select …
connect by {prior 列名1=列名2|列名1=prior列名2}
[start with];

最新文章

  1. WebSocket - ( 一.概述 )
  2. Win7 64位命令行编译cuda及设置Windows显卡响应时间
  3. [我给Unity官方视频教程做中文字幕]beginner Graphics – Lessons系列之纹理Textures
  4. c# UpdateLayeredWindow异形窗口
  5. 【抄】更改eclipse配置
  6. python 函数可变长参数
  7. vi编辑器基本用法介绍
  8. UVa 10003 (可用四边形不等式优化) Cutting Sticks
  9. Bzoj 2243: [SDOI2011]染色 树链剖分,LCT,动态树
  10. poj Monthly Expense
  11. 学习笔记:shell 中 [-eq] [-ne] [-gt] [-lt] [ge] [le]
  12. 使用LVS实现负载均衡原理及安装配置详解
  13. vue开发中遇到的问题集锦(2)
  14. 阿里云ACE共创空间——MQ消息队列产品测试
  15. ros 使用笔记
  16. invalid active developer path (/Library/Developer/CommandLineTools), missing xcrun at: /Library/Developer/CommandLineTools/usr/bin/xcrun
  17. js运行机制
  18. hibernate中带查询条件的分页
  19. mysql每天凌晨0点准时启动taskeng.exe如何关闭
  20. android 7.0拍照问题file:///storage/emulated/0/photo.jpeg exposed beyond app through ClipData.Item.getUri

热门文章

  1. OTG 接口烧写最小Linux的方法
  2. Unable to instantiate Action...............
  3. openSuSE DNS SERVER CONFIG
  4. C++Primer 第十四章
  5. PostgreSQL中initdb做了什么
  6. Leetcode: Number of Islands II && Summary of Union Find
  7. meta标签的理解
  8. [转]Hibernate不能自动建表解决办法及Hibernate不同数据库的连接及SQL方言
  9. 【皇甫】☀PPT里的小玩意
  10. 夺命雷公狗—angularjs—15—内置封装好的计时器$interval和$timeout