Oracle函數(shù)sys_connect_by_path 詳解:
語法:
Oracle函數(shù):sys_connect_by_path 主要用于樹查詢(層次查詢) 以及 多列轉(zhuǎn)行。其語法一般為:
select ... sys_connect_by_path(column_name,'connect_symbol') from table
start with ... connect by ... prior
理解:
對(duì)于數(shù)據(jù)庫來說,根節(jié)點(diǎn)并不一定是在數(shù)據(jù)庫中設(shè)計(jì)的頂級(jí)節(jié)點(diǎn),而是start with開始的地方。sys_connect_by_path函數(shù)就是從start with開始的地方開始遍歷,并記下其遍歷到的節(jié)點(diǎn),start with開始的地方被視為根節(jié)點(diǎn),將遍歷到的路徑根據(jù)函數(shù)中的分隔符,組成一個(gè)新的字符串。sys_connect_by_path函數(shù)用connect by來尋找下一條記錄,直到迭代找不到相應(yīng)記錄為止。概念與遞歸類似,connect by指定遞歸(連接)條件,如果條件不滿足則遞歸結(jié)束。
1. 查找一個(gè)員工的所有下屬員工。
start with ename='King' connect by prior empno= mgr;
我是這樣理解的:首先數(shù)據(jù)庫中的字段:empno--empname--mgr;這里從'King'開始,把'King'的編號(hào)做為管理編號(hào),然后在'King'編號(hào)為管理員的員工就是他的下屬(循環(huán)方式)。
2. 查找一個(gè)員工的所有上司經(jīng)理。
start with ename='King' connect by prior mgr= empno;
我是這樣理解的:首先數(shù)據(jù)庫中的字段:empno--empname--mgr;這里從'King'開始,把'King'的編號(hào)做為員工編號(hào),然后在'King'編號(hào)的gmr就是他的上司(迭代方式)。
下面是實(shí)驗(yàn):
--CREAT TABLE emp
create table emp ( empno varchar2(5), ename varchar2(8), mgr varchar2(8));
--INSERT DATA
insert into emp (EMPNO, ENAME, MGR)
values ('1', 'jim', '7');
insert into emp (EMPNO, ENAME, MGR)
values ('2', 'tom', '7');
insert into emp (EMPNO, ENAME, MGR)
values ('3', 'tim', '7');
insert into emp (EMPNO, ENAME, MGR)
values ('4', 'lily', '7');
insert into emp (EMPNO, ENAME, MGR)
values ('5', 'mary', '7');
insert into emp (EMPNO, ENAME, MGR)
values ('6', 'tid', '7');
insert into emp (EMPNO, ENAME, MGR)
values ('7', 'King', '10');
insert into emp (EMPNO, ENAME, MGR)
values ('8', 'kenvin', '10');
insert into emp (EMPNO, ENAME, MGR)
values ('9', 'shema', '8');
insert into emp (EMPNO, ENAME, MGR)
values ('10', 'john', '0');
insert into emp (EMPNO, ENAME, MGR)
values ('0', 'root', '');
--查詢語句:
1.顯示:'King'下的員工
select sys_connect_by_path(ename,'/') tree from emp start with ename='King' connect by prior empno= mgr;
2.顯示:'King'的上司
select sys_connect_by_path(ename,'/') tree,level from emp start with ename='King' connect by prior mgr= empno;