1. 程式人生 > >Oracle函數sys_connect_by_path 詳解

Oracle函數sys_connect_by_path 詳解

varchar 實驗 列轉行 叠代 輸出格式 image tom 技術分享 函數

Oracle函數sys_connect_by_path 詳解

語法:
Oracle函數:sys_connect_by_path 主要用於樹查詢(層次查詢) 以及 多列轉行。其語法一般為:
select ... sys_connect_by_path(column_name,‘connect_symbol‘) from table
start with ... connect by ... prior
理解:
對於數據庫來說,根節點並不一定是在數據庫中設計的頂級節點,而是start with開始的地方。sys_connect_by_path函數就是從start with開始的地方開始遍歷,並記下其遍歷到的節點,start with開始的地方被視為根節點,將遍歷到的路徑根據函數中的分隔符,組成一個新的字符串。sys_connect_by_path函數用connect by來尋找下一條記錄,直到叠代找不到相應記錄為止。概念與遞歸類似,connect by指定遞歸(連接)條件,如果條件不滿足則遞歸結束。

1. 查找一個員工的所有下屬員工。

start with ename=‘King‘ connect by prior empno= mgr;
我是這樣理解的:首先數據庫中的字段:empno--empname--mgr;這裏從‘King‘開始,把‘King‘的編號做為管理編號,然後在‘King‘編號為管理員的員工就是他的下屬(循環方式)。

2. 查找一個員工的所有上司經理。

start with ename=‘King‘ connect by prior mgr= empno;
我是這樣理解的:首先數據庫中的字段:empno--empname--mgr;這裏從‘King‘開始,把‘King‘的編號做為員工編號,然後在‘King‘編號的gmr就是他的上司(叠代方式)。

下面是實驗:

--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‘, ‘‘);

SELECT * FROM emp;

技術分享圖片

select sys_connect_by_path(ename,‘>‘) tree from emp start with ename=‘King‘ connect by prior empno = mgr;

技術分享圖片

select sys_connect_by_path(ename,‘/‘) tree from emp start with ename=‘King‘ connect by prior empno = mgr; --可以理解為查詢king的員工 ‘>’與‘/’只是一個輸出格式

技術分享圖片

select sys_connect_by_path(ename,‘/‘) tree from emp start with ename=‘King‘ connect by empno= prior mgr; --可以理解為查詢king的領導 效果與connect by prior mgr= empno相同

select sys_connect_by_path(ename,‘/‘) tree,level from emp start with ename=‘King‘ connect by prior mgr= empno;--可以理解為查詢king的領導

技術分享圖片

總結(自己理解):connect by prior column1 = column2 或者 connect by column2 = prior column1 寫法都可以,

主要看prior寫在誰的前面,prior寫在誰的前面誰就作為父級值(參照值),也就是說[connect by prior column1 = column2]的意思就是是 按start with 條件查詢出的記錄行,以column1為參考值,查詢column2為column1值的記錄。

轉自:https://www.cnblogs.com/shulmblogs/archive/2011/09/29/2195236.html

Oracle函數sys_connect_by_path 詳解