Oracle函数 SYS_CONNECT_BY_PATH()函数的应用

8 篇文章 1 订阅
  • 语法:

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');

insert into emp (EMPNO, ENAME, MGR)  values ('2', 'tom', '7');

insert into emp (EMPNO, ENAME, MGR)  values ('3', 'tim', '7');

insert into emp (EMPNO, ENAME, MGR)  values ('4', 'lily', '7');

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,e.*,level 
  from emp e
 start with ename = 'King'
connect by prior empno = mgr;

显示:‘King’下的员工

 2.显示:'King'的上司
select sys_connect_by_path(ename, '/') tree,e.*, level
  from emp  e
 start with ename = 'King'
connect by prior mgr = empno;

显示:‘King’的上司

 


数据仓库大数据开发学习的心路历程

https://blog.csdn.net/weixin_42163563/article/details/81943758

  • 12
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

胖哥真不错

您的鼓励,将是我最大的坚持!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值