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;

相关文章
相关标签/搜索