oracle中的递归查询语句

  创建一个demo表 department:

create table department (
 code VARCHAR2(10) not null,
 name VARCHAR2(50),
 pcode VARCHAR2(10),
 mgrname VARCHAR2(50)
);
insert into department values('ROOT','顶级部门', null, 'R大大');
insert into department values('A','A部门', 'ROOT', 'A老大');
insert into department values('A01','A01部门', 'A', 'A01老大');
insert into department values('A02','A02部门', 'A', 'A02老大');
insert into department values('B','B部门', 'ROOT', 'B老大');
insert into department values('B01','B01部门', 'B', 'B01老大');
insert into department values('B02','B02部门', 'B', 'B02老大');

1.递归查询某个部门的所有子级部门: 

select t.* from department t start with t.code='ROOT' connect by prior t.code = t.pcode ;

  查询结果:

  

 2.递归查询某个部门的所有上级部门:

select t.* from department t start with t.code='B02' connect by t.code = prior t.pcode ;

  查询结果:

  

原文地址:https://www.cnblogs.com/itfeng813/p/14086173.html