以下內(nèi)容來自http://hi.baidu.com/suofang/blog/item/a58bdd5829d5e583800a1812.html(其中的圖片可到這個(gè)地址查看)
connect by prior start with 經(jīng)常會(huì)被用到一個(gè)表中存在遞歸關(guān)系的時(shí)候。比如我們經(jīng)常會(huì)將一個(gè)比較復(fù)雜的目錄樹存儲(chǔ)到一個(gè)表中。或者將一些部門存儲(chǔ)到一個(gè)表中,而這些部門互相有隸屬關(guān)系。這個(gè)時(shí)候你就會(huì)用到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及其下面的所有數(shù)據(jù),則:
select * from table connect by prior a=b start with a=2
a b
2 1
4 2
這些只是基礎(chǔ),皮毛。其實(shí)只要你靈活的構(gòu)造查詢語句。可以得出意想不到的結(jié)果。比如生成樹每一個(gè)路徑。
但是這些記錄組成的樹必須正常才可以。如果有互為父子的情況,就會(huì)出現(xiàn)循環(huán)錯(cuò)誤!
示例:
 '800')this.width='800';if(this.height>'600')this.height='600';" border=0>
表結(jié)構(gòu)圖
 '800')this.width='800';if(this.height>'600')this.height='600';" border=0>
表數(shù)據(jù)
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
*************************自己總結(jié) 還是看CSDN吧,賽迪總是不好用http://writeblog.csdn.net/PostList.aspx*********************************
ORACLE查詢樹型關(guān)系(connect by prior start with)
有如下表結(jié)構(gòu):
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)
);
數(shù)據(jù)如下:
--子查父(通過子節(jié)點(diǎn)向根節(jié)點(diǎn)追朔.)
查詢〔特下邊〕的父節(jié)點(diǎn)
select FsysId,FSortName,FSortTopId,FSortAddress,FSortIsList from TVideoSort
start with FsysId='3703E5CD81E48D6BE040007F01001254'--這個(gè)是特下邊的fsysid
connect by prior FSortTopId=FsysId
order by FsortAddress
結(jié)果
――父查子(通過根節(jié)點(diǎn)遍歷子節(jié)點(diǎn).)
查詢〔特下邊〕的子節(jié)點(diǎn):結(jié)果
select FsysId,FSortName,FSortTopId,FSortAddress,FSortIsList
from TVideoSort start with FsysId='3703E5CD81E48D6BE040007F01001254' --這個(gè)是特下邊的fsysid
connect by prior FsysId=FSortTopId order by FsortAddress
查詢〔特長(zhǎng)練習(xí)〕的子節(jié)點(diǎn):結(jié)果
select FsysId,FSortName,FSortTopId,FSortAddress,FSortIsList
from TVideoSort start with FsysId='36AE4D68EC7D364CE040007F01000CA5'
connect by prior FsysId=FSortTopId order by FsortAddress
特別注意,兩個(gè)查詢只是FsysId=FSortTopId不同而已,即子查父則把FSortTopId做為主表放前面,父查子則把FsysId放前面作主表
|