加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

oracle中 sql语句:start with .. connect by prior.. 用法

发布时间:2020-12-12 15:49:21 所属栏目:百科 来源:网络整理
导读:见:http://blog.csdn.net/tzbiao/article/details/8632031 又见:http://blog.csdn.net/tzbiao/article/details/8632031 maven/ Java /web/bootstrap/dataTable/app开发 QQ群:566862629。希望更多人一起帮助我学习。 我们经常会将一个比较复杂的目录树存储

见:http://blog.csdn.net/tzbiao/article/details/8632031

又见:http://blog.csdn.net/tzbiao/article/details/8632031



maven/Java/web/bootstrap/dataTable/app开发QQ群:566862629。希望更多人一起帮助我学习。



我们经常会将一个比较复杂的目录树存储到一个表中。或者将一些部门存储到一个表中,而这些部门互相有隶属关系。这个时候你就会用到connect by prior start with。oracle 提供了start with connect by 语法结构可以实现递归查询。

connect by 是结构化查询中用到的,其基本语法是:

  select ... from tablename start with 条件1

  connect by prior 条件2

  where 条件3;

  例:

  select * from table

  start with org_id = 'HBHqfWGWPy'

  connect by prior org_id = parent_id;

  简单说来是将一个树状结构存储在一张表里,比如一个表中存在两个字段:

  org_id,parent_id那么通过表示每一条记录的parent是谁,就可以形成一个树状结构。

  用上述语法的查询可以取得这棵树的所有记录。

  其中:

  条件1 是根结点的限定语句,当然可以放宽限定条件,以取得多个根结点,实际就是多棵树。

  条件2 是连接条件,其中用PRIOR表示上一条记录,比如 CONNECT BY PRIOR org_id = parent_id就是说上一条记录的org_id 是本条记录的parent_id,即本记录的父亲是上一条记录。

  条件3 是过滤条件,用于对返回的所有记录进行过滤。

例如:

没有加中start with ... connect by prior ...的查询结果:

select t.dim_id,t.pid,level

from pmcode.pmcode_fj_tree_rl t

where t.dim_id in (select b.dim_id

from pmcode.PMCODE_KPI_DIM_OD b

where b.kpi_id = 'KC0011')

结果:

DIM_ID PID LEVEL

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

1024 5003 0

1070 0 0

5003 1070 0

5006 0 0

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

增加start with ... connect by prior ...以后的结果:

start with t.dim_id = '1070' ----表示从dim_id = '1070'开始(也就是说1070为根节点)

connect by prior t.dim_id = t.pid; ----表示上条记录的dim_id等于本条记录的pid

1070 0 1

5003 1070 2

1024 5003 3


又如:

1. 一个简单举例:
SQL> select *from test;

BILL_MONTHDAY_NUMBER MSISDN
-------------------- ---------- --------------------
2008031 13800
3 13800
2 13800
2 13801
4 13804
5 13804
7 13804
8 13804
6 13802
6 13801
7 13801
8 13801
12 rows selected
SQL>
SQL> select * from test
2start with day_number=1
3connect byprior day_number=day_number-1 and prior msisdn= msisdn
4;
上面的语句查找出了从1开始,并且day_number 逐渐+1 递增的,并且 msisdn 相同的哪些个数据.
2. start withconnect by 语法结构
如上面说看到的 例子, 其语法结构为start with conditioncondition (含 prior 关键字)
start with conditon 给出的seed 数据的范围,connect by后面给出了递归查询的条件,prior 关键字表示父数据,prior 条件表示子数据需要满足父数据的什么条件。
在下面的这个start with connect by 结构中,就表示 查找出了从1开始,父数据的day_number等于子数据的day_number-1而且父数据的msisdn=子数据的msisdn.
prior day_number=day_number-1 and prior msisdn= msisdn

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读