oracle 递归 level

drop table automobiles
create table automobiles(
       part_id number(5)
         constraint pk_auto_part_id primary key,
       parent_id number(5)
         constraint fk_auto_ppid_ references  automobiles(part_id),
       part_cname varchar2(30) not null,
       part_ename varchar2(30) not null,
       mp_cost number(9,2),
       desribe varchar2(20)    
);

--插入数据
insert into automobiles values( 1,null,'汽车','mobile',84321.99,'Assembly');
insert into automobiles values( 2,1,'车身','bodywork',19892.99,'Manufacture');
insert into automobiles values( 3,1,'发送机','engine',42128,'Purchase');
insert into automobiles values( 4,1,'附件','attached',15212,'Assembly');
insert into automobiles values( 5,2,'保险杠','bumper',4812.95,'Purchase');
insert into automobiles values( 6,2,'底盘','chassis',12795.11,'Manufacture');
insert into automobiles values( 7,2,'行李箱','Boot',812.11,'Manufacture');
--分层sql脚本语句练习
select level,part_id,parent_id,part_cname,part_ename,mp_cost,desribe
from automobiles
start with part_id=1
connect by prior part_id=parent_id
order by level;
--缩进显示
select level,
    lpad(' ',2*level-1)||part_cname||' '||part_ename as partName
from automobiles
start with part_id=1
connect by prior part_id=parent_id
order by level;
--使用子查询
select level,lpad(' ',2*level-1)||part_cname||' '||part_ename as partName from automobiles
start with part_id=(select part_id from automobiles where part_cname like '%轴%')
connect by prior  part_id=parent_id
order by level;
--自底向上的遍历
select level,lpad(' ',2*level-1)||part_cname||' '||part_ename as partName
from automobiles
start with part_id=(select part_id from automobiles where part_cname like '%轴%')
connect by prior parent_id=part_id
order by level;
--删除指定的节点
select level,lpad(' ',2*level-1)||part_cname||' '||part_ename as partName from automobiles
where part_cname <> '底盘'
start with part_id=1
connect by prior parent_id=part_id
order by level
--删除分支
select level,lpad(' ',2*level-1)||part_cname||' '||part_ename as partName from automobiles
start with part_id=1
connect by prior parent_id=part_id and part_cname <> '底盘'
order by level;

Oracle中的递归可以通过使用`WITH`子句和`CONNECT BY`子句来实现。这种递归查询方式被称为“递归公共表达式(Recursive Common Table Expression)”。 下面是一个简单的递归查询的例子,假设我们有一个员工表`EMP`,其中有一个字段`MGR`表示员工的上级经理: ``` EMPNO ENAME JOB MGR 1 John Manager NULL 2 Bob Clerk 1 3 Alice Clerk 1 4 Tom Analyst 2 5 Mary Analyst 3 6 Jack Salesman 1 ``` 我们可以使用递归查询来查找每个员工的所有下属,包括直接下属和间接下属。下面是一个使用递归查询的示例: ``` WITH emp_tree AS ( SELECT empno, ename, job, mgr, 0 AS level FROM emp WHERE mgr IS NULL UNION ALL SELECT emp.empno, emp.ename, emp.job, emp.mgr, emp_tree.level + 1 FROM emp_tree JOIN emp ON emp.mgr = emp_tree.empno ) SELECT empno, ename, job, level FROM emp_tree ORDER BY level, empno; ``` 在上面的查询中,我们首先定义了一个递归公共表达式`emp_tree`,它包含了所有顶级经理的信息。然后我们使用`UNION ALL`运算符将顶级经理和他们的直接下属组合在一起,并将`level`设置为0。接下来,我们使用`JOIN`运算符将每个下属与其直接上级经理连接起来,并将`level`设置为上级经理的`level + 1`。最后,我们从递归公共表达式`emp_tree`中选择所有下属的信息,并按照`level`和`empno`排序。 执行以上查询的结果如下: ``` EMPNO ENAME JOB LEVEL ---- ------ --------- ----- 1 John Manager 0 2 Bob Clerk 1 3 Alice Clerk 1 6 Jack Salesman 1 4 Tom Analyst 2 5 Mary Analyst 2 ``` 在这个结果中,我们可以看到每个员工的编号、姓名、职位和级别。其中,顶级经理的级别为0,直接下属的级别为1,间接下属的级别为2。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值