對於oracle進行簡單樹查詢(遞迴查詢)deptid paredeptid name
number
number
char (40
byte)
部門id 父部門id(所屬部門id) 部門名稱
通過子節點向根節點追朔.
sql**
select
*from persons.dept start with deptid=
76 connect by prior paredeptid=
deptid
select
*from persons.dept start with deptid=
76 connect by prior paredeptid=
deptid
通過根節點遍歷子節點.
sql**
select
*from persons.dept start with paredeptid=
0 connect by prior deptid=
paredeptid
select
*from persons.dept start with paredeptid=
0 connect by prior deptid=
paredeptid
可通過level 關鍵字查詢所在層次.
sql**
select a.*,level
from persons.dept a start with paredeptid=
0 connect by prior deptid=
paredeptid
select a.*,level
from persons.dept a start with paredeptid=
0 connect by prior deptid=
paredeptid
再次複習一下:start
with ...connect by 的用法, start with
後面所跟的就是就是遞迴的種子。
遞迴的種子也就是遞迴開始的地方 connect
by後面的"prior" 如果預設:則只能查詢到符合條件的起始行,並不進行遞迴查詢;
connect
byprior 後面所放的字段是有關係的,它指明了查詢的方向。
練習: 通過子節點獲得頂節點
sql**
select first_value(deptid) over (order
bylevel
desc rows unbounded preceding) as firstdeptid from persons.dept start with deptid=
76 connect by prior paredeptid=deptid
oracle 遞迴查詢 Oracle遞迴查詢
1.1 建立表與插入資料 create table district id number 10 not null,parent id number 10 name varchar2 255 byte not null alter table district add constraint distr...
oracle 逆向遞迴查詢 oracle遞迴查詢
oracle的遞迴查詢 最近在看公司的oa系統,oa系統中基本都會有節點樹,其中對於樹上的資料展示,就是用了資料庫的遞迴查詢,在這裡總結下遞迴查詢。現在存在如下的一棵樹 不會畫樹,將就一下,該樹對應下面建立的表資料。建立如下表 create table dg id number not null,主...
oracle 逆向遞迴查詢 Oracle遞迴查詢
start with.connect by子句遞迴查詢一般用於乙個表維護樹形結構的應用。建立示例表 create table tbl test id number,name varchar2 100 byte pid number default 0 插入測試資料 insert into tbl t...