oracle中的start with

一,基本语法

SELECT ... FROM    + 表名 
[START WITH         + 条件1]
CONNECT BY PRIOR   + 条件2
WHERE              + 条件3

条件1:是根节点的限定语句,当然可以放宽限定条件,以取得多个根节点,也就是多棵树;在连接关系中,除了可以使用列明外,还允许使用列表达式。
START WITH 子句为可选项,用来标识哪个节点作为查找树形结构的根节点若该子句省略,则表示所有满足查询条件的行作为根节点。
条件2:是连接条件,其中用PRIOR表示上一条记录,例如CONNECT BY PRIOR STUDENT_ID = GRADE_ID,意思就是上一条记录的STUDENT_ID是本条记录的GRADE_ID,即本记录的父亲是上一条记录。CONNECT BY子句说明每行数据将是按照层次顺序检索,并规定将表中的数据连入树形结构的关系中。
PRIOR运算符必须放置在连接关系的2列中某一个的前面。对于节点间的父子关系,PRIOR运算符在一侧表示父节点,在另一侧表示子节点,从而确定查找树结构的顺序是自顶向下,还是自底向上。
条件3:是过滤条件,用于对返回的记录进行过滤。

1,定义查找起始节点
    在自顶向下查询树状结构时,不但可以从根节点开始,还可以定义任何节点为起始节点,以此开始,向下查找。这样查找的结果就是以该节点为开始
的结构是树的一枝。

看一个例子:
SELECT * FROM STUDENT 
START WITH STUDENT_ID = '00001'
CONNECT BY PRIOR STUDENT_ID = GRADE_ID;

1,CONNECT BY PRIOR是结构化查询中用到的;
2,START WITH... CONNECT BY PRIOR...的作用,简单来说,就是将一个树状结构存储在一张表里。

假如一个表里存在2个字段:STUDENT_ID(学生ID)、GRADE_ID(班级ID),那么我们可以通过表示每一个学生属于哪一个班级,来形成一个树状结构,通过START WITH... CONNECT BY PRIOR...语法,就可以取得这棵树的所有记录。

--自顶向下 以BRH_ID = '0003'这个节点为根节点,向下查询
SELECT * FROM IM_BRANCH 
START WITH BRH_ID = '0003'
CONNECT BY PRIOR BRH_ID = BRH_PARENTID

--自底向上 以BRH_ID = '0003'这个节点为叶节点,向上查询
SELECT * FROM IM_BRANCH 
START WITH BRH_ID = '0003'
CONNECT BY BRH_ID = PRIOR BRH_PARENTID

二,应用场景

    START WITH... CONNECT BY PRIOR...常见的用法,是用来遍历含有父子关系的表结构中。比如省市关系,一个省
下面包含多个城市,如果城市基本信息表中,包含有属于哪个省级的字段,那么如果要遍历所有的城市,我们就可以

使用START WITH... CONNECT BY PRIOR...。

oracle 提供了start with connect by 语法结构可以实现递归查询。

1. 一个简单举例:

SQL> select *  from test;

BILL_MONTH           DAY_NUMBER          MSISDN

--------------------          ----------                      --------------------

200803                        1                                 13800

200803                        3                                 13800

200803                        2                                 13800

200803                        2                                 13801

200803                        4                                 13804

200803                        5                                 13804

200803                        7                                 13804

200803                        8                                 13804

200803                        6                                 13802

200803                        6                                 13801

200803                        7                                 13801

200803                        8                                 13801

12 rows selected

SQL>

SQL> select * from test

  2       start with day_number=1

  3       connect by  prior day_number=day_number-1 and prior msisdn= msisdn;

BILL_MONTH           DAY_NUMBER         MSISDN

--------------------          ----------                     --------------------

200803                        1                              13800

200803                        2                              13800

200803                        3                              13800

上面的语句查找出了从1开始,并且day_number 逐渐+1 递增的,并且 msisdn 相同的哪些个数据.

2. start with  connect by 语法结构

 如上面说看到的 例子, 其语法结构为  start with condition  connect by  condition (含 prior 关键字)

start with conditon 给出的seed 数据的范围, connect by  后面给出了递归查询的条件,prior 关键字表示父数据,prior 条件表示子数据需要满足父数据的什么条件。

在下面的这个start with connect by 结构中,就表示 查找出了从1开始,父数据的day_number等于子数据的day_number-1而且父数据的msisdn=子数据的msisdn.

start with day_number=1

     connect by  prior day_number=day_number-1 and prior msisdn= msisdn

  • 12
    点赞
  • 35
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值