随笔-17  评论-64  文章-79  trackbacks-1
ORACLE查询树型关系(connect by prior start with)
2007年07月26日 星期四 上午 10:26

connect by prior start with 经常会被用到一个表中存在递归关系的时候。比如我们经常会将一个比较复杂的目录树存储到一个表中。或者将一些部门存储到一个表中,而这些部门互相有隶属关系。这个时候你就会用到connect by prior start with。

典型的使用方法就是:
select * from table connect by prior cur_id=parent_id start with cur_id=???
例如:
a          b
1         0
2         1
3         1
4         2
5         3

如果想查找a=2及其下面的所有数据,则:
select * from table connect by prior a=b start with a=2
a         b
2         1
4         2

这些只是基础,皮毛。其实只要你灵活的构造查询语句。可以得出意想不到的结果。比如生成树每一个路径。
但是这些记录组成的树必须正常才可以。如果有互为父子的情况,就会出现循环错误!

示例:

C_AREA_CDE  C_SNR_AREA
1             
101       1
   103       1   

表数据

select * from tb_cus_area_cde

--子取父
select * from tb_cus_area_cde a    
CONNECT BY PRIOR   a.c_snr_area=a.c_area_cde START WITH a.c_area_cde='1040101'

--父取子
select * from tb_cus_area_cde a    
CONNECT BY PRIOR   a.c_area_cde=a.c_snr_area START WITH a.c_snr_area is null

posted on 2007-09-12 13:12 飞鸟 阅读(657) 评论(0)  编辑  收藏 所属分类: 数据库

只有注册用户登录后才能发表评论。


网站导航: