• 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找的就是根节点。

  • 好了简单的递归查询原理介绍完了,希望大家回去实验一下,即使说不出什么原理,但是起码先会用了再说。

  • 本文来之:http://jingyan.baidu.com

最新文章

  1. css 水平垂直居中总结
  2. python抓取某学院视频
  3. 一次外企QQ面试
  4. visual studio 局域网远程调试web项目
  5. leetcode 128. Longest Consecutive Sequence ----- java
  6. VS2010出现灾难性错误的解决办法
  7. 【128】Word中的VBA
  8. android 使某个控件获取焦点
  9. phpcms 2008 /preview.php SQL注入漏洞
  10. Objective-c初始化和便利构造
  11. JAVA设计模式:蝇量模式
  12. 二分图最大匹配模板【匈牙利;Dinic最大流】
  13. git常用命令二、:git stash
  14. 介绍一款自动给添加不同浏览器CSS3前缀的插件~Autoprefixer(附其他前端开发插件)
  15. 生成N位数字随机数
  16. Linux内核源码分析 day01——内存寻址
  17. 给Linux系统新增加一块硬盘
  18. 未能加载文件或程序集 Microsoft.ReportViewer.ProcessingObjectModel, Version=10.0.0.0…错误问题的解决
  19. Min_25 筛
  20. Scala泛型[T]的使用

热门文章

  1. 关于将ECharts引入到项目中的几种方式
  2. 实现一个koa-logger中间件
  3. 高德地图定位不到 报错 location Error, ErrCode:7, errInfo:KEY错误 请到http://lbs.amap.com/api/android-location-sdk/abouterrorcode/查看错误码说明.
  4. virtualbox 启动虚拟机提示Cannot load R0 module
  5. 「EJOI2017」-骆驼
  6. go 交叉编译扩展 ac68u 梅林固件, go 依赖 zoneinfo 的解决问题
  7. 【JSOI2018】绝地反击
  8. PAT甲级——A1010 Radix
  9. [转载] DDK中VPORT Mini-Driver的使用说明
  10. debian下编译安装poco