ORACLE查询树型关系

ORACLE查询树型关系(connect by prior start with)

以下内容来自http://hi.baidu.com/suofang/blog/item/a58bdd5829d5e583800a1812.html(其中的图片可到这个地址查看)
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
这些只是基础,皮毛。其实只要你灵活的构造查询语句。可以得出意想不到的结果。比如生成树每一个路径。
但是这些记录组成的树必须正常才可以。如果有互为父子的情况,就会出现循环错误!
示例:

'800')this.width='800';if(this.height>'600')this.height='600';" border=0>
表结构图
'800')this.width='800';if(this.height>'600')this.height='600';" border=0>
表数据
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

*************************自己总结 还是看CSDN吧,赛迪总是不好用http://writeblog.csdn.net/PostList.aspx*********************************
ORACLE查询树型关系(connect by prior start with
有如下表结构:
create table TVideoSort
(
FsysId       NVARCHAR2(32 char)       not null,
FSortName       NVARCHAR2(32 char),
FSortTopId     NVARCHAR2(32 char),
FSortAddress     number,
FSortIsList     char(1),
constraint PK_TVIDEOSORT primary key (FsysId)
);





数据如下:




--子查父(通过子节点向根节点追朔.
查询〔特下边〕的父节点
select FsysId,FSortName,FSortTopId,FSortAddress,FSortIsList from TVideoSort
start with FsysId=
'3703E5CD81E48D6BE040007F01001254'--这个是特下边的fsysid
connect by prior
FSortTopId=FsysId
order by FsortAddress

结果




――父查子(通过根节点遍历子节点.

查询〔特下边〕的子节点:结果
select FsysId,FSortName,FSortTopId,FSortAddress,FSortIsList
from TVideoSort start with FsysId=
'3703E5CD81E48D6BE040007F01001254' --这个是特下边的fsysid
connect by prior FsysId=FSortTopId order by FsortAddress



查询〔特长练习〕的子节点:结果
select FsysId,FSortName,FSortTopId,FSortAddress,FSortIsList
from TVideoSort start with FsysId=
'36AE4D68EC7D364CE040007F01000CA5'
connect by prior
FsysId=FSortTopId order by FsortAddress





特别注意,两个查询只是
FsysId=FSortTopId不同而已,即子查父则把FSortTopId做为主表放前面,父查子则把FsysId放前面作主表

posted on 2007-11-30 13:51 Tom 阅读(2069) 评论(0)  编辑  收藏 所属分类: DB


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


网站导航:
 
<2007年11月>
28293031123
45678910
11121314151617
18192021222324
2526272829301
2345678

导航

统计

常用链接

留言簿(1)

随笔分类(42)

随笔档案(43)

文章分类

相册

搜索

最新评论

阅读排行榜

评论排行榜