oracle SQL简介(二)

本文介绍了如何使用Oracle数据库中的CONNECT BY语法进行树结构查询,包括从树干向上查询、从树根向下查询、删除指定节点及其下属的方法,并展示了生成年份列表的具体实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

函数,树结构查询,连接查询,子查询, 优化

2.   树结构查询(connect by)

从树干开始,向上查:

select level,empno,ename,mgr from emp

start with (empno= 7369)

connect by prior mgr=empno;

 

select level, EMPLOYEE_ID,FIRST_NAME,MANAGER_ID from employees

start with (EMPLOYEE_ID= 206)

connect by prior MANAGER_ID=EMPLOYEE_ID;

 

从树根开始,向下查:

select level,empno,ename,mgr from emp

start with (mgr is null)

connect by prior empno=mgr;

 

select level, EMPLOYEE_ID,FIRST_NAME,MANAGER_ID from employees

start with (MANAGER_ID is null)

connect by prior EMPLOYEE_ID = MANAGER_ID;

 

删除节点,下级保留

select level,empno,ename,mgr from emp

where ename<>'BLAKE'

start with (mgr is null)

connect by prior empno=mgr;

删除树干,包括下属

select level,empno,ename,mgr from emp

start with (mgr is null)

connect by prior empno=mgr

and ename<>'BLAKE';

生成年份列表

select 1949 + rownum - 1 as year  from dual

connect by 1949 + rownum - 1 <= extract(year from sysdate)

order by year desc;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值