start with ...connect by的用法

简介:

 
 
  1. Start with...Connect By子句递归查询一般用于一个表维护树形结构的应用。  
  2. 创建示例表:  
  3. CREATE TABLE TBL_TEST  
  4. (  
  5. ID NUMBER,  
  6. NAME VARCHAR2(100 BYTE),  
  7. PID NUMBER DEFAULT 0  
  8. );  
  9. 插入测试数据:  
  10. INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('1','10','0');  
  11. INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('2','11','1');  
  12. INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('3','20','0');  
  13. INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('4','12','1');  
  14. INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('5','121','2');  
  15. 从Root往树末梢递归  
  16. select * from TBL_TEST  
  17. start with id=1  
  18. connect by prior id = pid  
  19. 从末梢往树ROOT递归  
  20. select * from TBL_TEST  
  21. start with id=5  
  22. connect by prior pid = id  
  23. =====  
  24. 简单说来是将一个树状结构存储在一张表里,比如一个表中存在两个字段:  
  25. id,pid那么通过表示每一条记录的parent是谁,就可以形成一个树状结构。  
  26. 用上述语法的查询可以取得这棵树的所有记录。  
  27. 其中:  
  28.  
  29. 条件1 是根结点的限定语句,当然可以放宽限定条件,以取得多个根结点,实际就是多棵树。  
  30. 条件2 是连接条件,其中用PRIOR表示上一条记录,比如 CONNECT BY PRIOR id = pid就是说上一条记录的id 是本条记录的pid,即本记录的父亲是上一条记录。  
  31. 条件3 是过滤条件,用于对返回的所有记录进行过滤。  
  32.  
  33.  
  34.  
  35. 简单介绍如下:  
  36.  
  37. 早扫描树结构表时,需要依此访问树结构的每个节点,一个节点只能访问一次,其访问的步骤如下:  
  38. 第一步:从根节点开始;  
  39. 第二步:访问该节点;  
  40. 第三步:判断该节点有无未被访问的子节点,若有,则转向它最左侧的未被访问的子节,并执行第二步,否则执行第四步;  
  41. 第四步:若该节点为根节点,则访问完毕,否则执行第五步;  
  42. 第五步:返回到该节点的父节点,并执行第三步骤。  
  43.  
  44. 总之:扫描整个树结构的过程也即是中序遍历树的过程。  
  45.  
  46.  
  47. 按照上面给的分析即可对表中的数据构进行分析,以上的方法只适合表中有一棵树的情况。 

 


本文转自sucre03 51CTO博客,原文链接:http://blog.51cto.com/sucre/380296,如需转载请自行联系原作者

相关文章
|
5月前
|
SQL
启动mysq异常The server quit without updating PID file [FAILED]sql/data/***.pi根本解决方案
启动mysq异常The server quit without updating PID file [FAILED]sql/data/***.pi根本解决方案
55 0
|
4月前
|
弹性计算 监控 Serverless
函数计算操作报错合集之调用不成功,报错:Function instance health check failed on port 9000 in 120.7 seconds.该怎么办
在使用函数计算服务(如阿里云函数计算)时,用户可能会遇到多种错误场景。以下是一些常见的操作报错及其可能的原因和解决方法,包括但不限于:1. 函数部署失败、2. 函数执行超时、3. 资源不足错误、4. 权限与访问错误、5. 依赖问题、6. 网络配置错误、7. 触发器配置错误、8. 日志与监控问题。
|
8天前
|
网络安全
client_loop: send disconnect: Connection reset by peerB/s4-5
client_loop: send disconnect: Connection reset by peerB/s4-5
|
5月前
|
网络协议 Linux API
Linux网络编程:shutdown() 与 close() 函数详解:剖析 shutdown()、close() 函数的实现原理、参数说明和使用技巧
Linux网络编程:shutdown() 与 close() 函数详解:剖析 shutdown()、close() 函数的实现原理、参数说明和使用技巧
369 0
|
2月前
|
监控 数据库连接 PHP
php中register_shutdown_function函数用法详解
通过 `register_shutdown_function`,PHP开发者可以对脚本的终止进行更精细化的处理,这个函数让开发者能在脚本的生命周期结束时有机会执行最后的操作,无论脚本是正常结束还是发生错误。由于它的高度实用性和灵活性,`register_shutdown_function`是PHP开发中不可或缺的工具之一。
41 0
|
NoSQL MongoDB
启动mongodb报错 Failed to set up listener: SocketException: Address already in use 解决办法
启动mongodb报错 Failed to set up listener: SocketException: Address already in use 解决办法
975 1
|
3月前
|
网络协议 关系型数据库 MySQL
启动mysql时的异常为:[ERROR] Can‘t start server: Bind on TCP/IP port. Got error: 98: Address already in used
启动mysql时的异常为:[ERROR] Can‘t start server: Bind on TCP/IP port. Got error: 98: Address already in used
|
3月前
|
应用服务中间件
It is possible to bind and connect to localhost:8080 at the same time - application server will prob
It is possible to bind and connect to localhost:8080 at the same time - application server will prob
End Sub 和 Exit Sub 的区别
End Sub 和 Exit Sub 的区别
127 0
End Sub 和 Exit Sub 的区别
脚本文件stop和status与start类似,这里不再描述。
脚本文件stop和status与start类似,这里不再描述。
50 0