递归查询 START WITH CONNECT BY PRIOR
来源:互联网 发布:淘宝买steam游戏礼物 编辑:程序博客网 时间:2024/05/16 05:23
START WITH CONNECT BY PRIOR这个语法主要用于查询数据包中的树型结构关系。先看下原始数据时怎么样的吧!
表中第一行1001是1002的父节点,而第二行1002又是1003的父节点,如此循环。如题:要求给出其中一个数字能找出其最终的根节点!应该要怎么样实现呢?请看如下sql语句,这里我就拿1008为例。图中第一行第一个num1就是根节点了。再来分析下sql语句:
select num1,num2,level
from carol_tmp
start with num2=1008
connect by num2=prior num1 order by level desc;
prior放的左右位置决定了检索是自底向上还是自顶向下.很明显以上的sql选择了自底向上,所以最终得到了根节点。
这次要求获得最小的叶节点,看下图:
第一行的num1就是最小的叶节点了,在注意看下sql代码和上面的代码有什么不同之处:
select num1,num2,level
from carol_tmp
start with num2=1008
connect by prior num2= num1 order by level desc;
这次prior和num2放在了一起,他意思就是从num2开始寻找其下面最小的叶节点。
为什么prior和谁在一起比较重要呢?比如prior和 num2同在等号的一边,这个时候要看num2和num1的关系。若num2一直是parent,那么这个sql找的就是根节点。
好了简单的递归查询原理介绍完了,希望大家回去实验一下,即使说不出什么原理,但是起码先会用了再说。
- 递归查询START WITH CONNECT BY PRIOR
- 递归查询 START WITH CONNECT BY PRIOR
- 用START WITH...CONNECT BY PRIOR子句实现递归查询
- oracle关键字 start with、、、 connect by prior 子句递归查询
- 让hibernate支持递归、start with connect by prior 查询
- oracle 递归查询 start with connect by prior
- 让hibernate支持递归、start with connect by prior 查询
- 让hibernate支持递归、start with connect by prior 查询
- Start with connect by prior 递归 树查询
- Oracle start with......connect by prior......子句实现递归查询
- Oracle start with.connect by prior子句实现递归查询
- Oracle start with.connect by prior子句实现递归查询
- Oracle start with.connect by prior子句实现递归查询
- Oracle start with.connect by prior子句实现递归查询
- Oracle start with.connect by prior子句实现递归查询
- Oracle start with...connect by prior 实现递归查询
- START WITH CONNECT BY PRIOR子句实现递归查询
- START WITH CONNECT BY PRIOR子句实现递归查询
- 《SpringCloud微服务实战》学习笔记之消息总线BUS-RabbitMQ
- 【传智播客郑州校区分享】职场小白到传智播客郑州校区学习变身技术达人
- go语言随便玩玩(linux环境)
- 计算机屏幕上的代码列
- Object类的这三个方法---equals、hashCode和clone方法关键技术剖析
- 递归查询 START WITH CONNECT BY PRIOR
- React D3.js pie chart | 解决label重叠的问题
- 裸辞之回炉重造(牛客网刷题总结)
- 最短路径导航系统
- IASyncResult接口实现简单异步编程
- Linux查看MySQL
- 5.6.1 boolean类型
- 阿里云服务器购买 发布web项目全过程
- 独家 | 5大冠军出炉!李开复的AI挑战赛,冠军们聊到了这么些感受