您的位置:首页 > 数据库 > Oracle

Oracle Connect by与递归with

2015-07-23 09:44 447 查看

层次查询

select
*
from emp;



select empno,

ename,

job,

mgr,

sal,

deptno,level lv,

sys_connect_by_path(ename,
'->') tree_path,

connect_by_root(ename) tree_root,

connect_by_isleaf isleaf,

decode(connect_by_isleaf,1,ename,null) tree_leaf

from emp

start
with empno =
7369

connect
by
prior mgr = empno

order
by
level,empno;



with t(empno,

ename,

job,

mgr,

sal,

deptno,

lv,

tree_path,

tree_root,

isleaf,tree_leaf)
as

(select empno,

ename,

job,

mgr,

sal,

deptno,

1 lv,

'->'||ename,

ename,

(select
decode(count(1),
0,
1)
from emp where a.mgr = empno) isleaf,

(select
decode(count(1),
0, a.ename)
from emp where a.mgr = empno) leafname

from emp a

where empno =
'7369'

union
all

select a.empno,

a.ename,

a.job,

a.mgr,

a.sal,

a.deptno,

b.lv +
1,

b.tree_path ||
'->'
|| a.ename,

b.tree_root,

(select
decode(count(1),
0,
1)
from emp where a.mgr = empno) isleaf,

(select
decode(count(1),
0,a.ename)
from emp where a.mgr = empno) leafname

from emp a, t b

where a.empno = b.mgr)

select
*
from t order
by lv,empno;

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: