ORACLE函數sys_connect_by_path

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');it

insert into emp (EMPNO, ENAME, MGR)
values ('2', 'tom', '7');io

insert into emp (EMPNO, ENAME, MGR)
values ('3', 'tim', '7');table

insert into emp (EMPNO, ENAME, MGR)
values ('4', 'lily', '7');select

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;

相關文章
相關標籤/搜索