Oracle高级函数篇之递归查询start with connect by prior简单用法

Posted 路飞

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle高级函数篇之递归查询start with connect by prior简单用法相关的知识,希望对你有一定的参考价值。

路飞:“ 把原来CSDN的博客转移到博客园咯!”
前段时间,自己负责的任务中刚好涉及到了组织关系的业务需求,自己用了oracle递归查询。下面简单来举个例子。在工作中我们经常会遇到有一定组织关系层次的关系。比如某个省下有多少市,每个市下又有多个区。再或者公司组织部门相互的隶属关系。这时我们就可能会用到 start with connect by prior 递归查询了
用法举例
1. 基本sql语法

select  ...   from  + 表
  start with       +    条件1
connect by  prior    +    条件2
  where             +     条件3
  
条件说明:
  条件1:是根节点的限定语句
  条件2:连接条件。prior表示上一条信息。比如connect by prior  org_id =     parent_id 就是说上一条记录的org_id是本条 记录的parent_id,即本记录的父亲是上一条记录。
  条件3:过滤条件

2. 用法举例:
表名:CITY_TREE,表结构如下:
图片
表数据:

=======================================================================
(1)从根节点向下查询:

select A.*from CITY_TREE A
STARTWITH A.CITY_ID =\'1\'
CONNECTBYPRIOR A.CITY_ID = A.CITY_PID;

结果如下图:

(2)从根节1点向上查

select A.* from CITY_TREE A 
START WITH A.CITY_ID = \'1\'
CONNECT BY A.CITY_ID = PRIOR A.CITY_PID;

结果如下图:

以上是关于Oracle高级函数篇之递归查询start with connect by prior简单用法的主要内容,如果未能解决你的问题,请参考以下文章

Oracle 递归查询 (start with ...connect by ...prior)

Oracle递归查询start with connect by prior

好玩的ES--第二篇之高级查询,索引原理和分词器

oracle树形查询 start with connect by

MySQL入门篇之高级查询

sql语句递归查询(start with)