oracle之sys_connect_by_path函数

1. sys_connect_by_path 详解 ------------oracle9i 开始有的自带函数(用于解决团队关系等)

语法:
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', '');
SELECT * FROM emp;

表结构:

 3.

select sys_connect_by_path(ename,'>') tree from emp start with ename='King' connect by prior empno = mgr;

select sys_connect_by_path(ename,'/') tree from emp start with ename='King' connect by prior empno = mgr; --可以理解为查询king的员工 ‘>’与‘/’只是一个输出格式

 4.

select sys_connect_by_path(ename,'/') tree from emp start with ename='King' connect by empno= prior mgr; --可以理解为查询king的领导 效果与connect by prior mgr= empno相同

select sys_connect_by_path(ename,'/') tree,level from emp start with ename='King' connect by prior mgr= empno;--可以理解为查询king的领导

总结(自己理解):connect by prior column1 = column2 或者 connect by  column2 = prior column1 写法都可以,

主要看prior写在谁的前面,prior写在谁的前面谁就作为父级值(参照值),也就是说[connect by prior column1 = column2]的意思就是是 按start with 条件查询出的记录行,以column1为参考值,查询column2为column1值的记录。

以上转自:https://www.cnblogs.com/supermandy/p/7873233.html

下面来看一个应用题

有一份数据部分如下,比如:刘备和关羽有关系,说明他们是一个团伙,刘备和张飞也有关系,那么刘备、关羽、张飞归为一个团伙,以此类推。用自己熟悉的编程语言根据人员和相关人员计算出团伙分类;

 

答案1:

建表语句

drop table pop_gg;
create table pop_gg(pop_gg varchar2(10),pop_ggg varchar2(10));

truncate table pop_gg;

insert into pop_gg(pop_gg,pop_ggg) values('刘备','关羽');
insert into pop_gg(pop_gg,pop_ggg) values('刘备','张飞');
insert into pop_gg(pop_gg,pop_ggg) values('张飞','诸葛亮');
insert into pop_gg(pop_gg,pop_ggg) values('曹操','司马');
insert into pop_gg(pop_gg,pop_ggg) values('司马','张辽');
insert into pop_gg(pop_gg,pop_ggg) values('曹操','曹呸');

mysql (已知刘备、曹操为领导的情况)

SELECT DISTINCT 人员, if(人员 ='刘备',1,2) 团队分类 from names_1
WHERE 人员 in ('曹操','刘备')
UNION
SELECT 相关人员 人员,
if(人员='刘备',1,if(人员='曹操',2,(SELECT if(人员='刘备',1,2) FROM names_1 b WHERE b.相关人员=a.人员 ))) 团队分类
FROM names_1 a ORDER BY 团队分类;

Oracle

with tmp as
 (select pop_gg,
         pop_ggg,
         sys_connect_by_path(pop_gg, '/') || '/' || pop_ggg as s,
         substr(sys_connect_by_path(pop_gg, '/') || '/' || pop_ggg,
                1,
                instr(sys_connect_by_path(pop_gg, '/') || '/' || pop_ggg,
                      '/',
                      1,
                      2)) as ss
    from pop_gg
   start with pop_gg in
              (select distinct pop_gg
                 from pop_gg
                where pop_gg not in (select pop_ggg from pop_gg)) -- 求出来父级
  connect by prior pop_ggg = pop_gg
  union all -- 拼接父级
  select distinct pop_gg, pop_gg, '/' || pop_gg || '/', '/' || pop_gg || '/'
    from pop_gg
   where pop_gg not in (select pop_ggg from pop_gg))
select --pop_gg, 
 pop_ggg,
 -- ss,
 dense_rank() over(order by ss asc) as td
  from tmp;

 

 

 转自:​​​​​​团伙分类:有一份数据部分如下,比如:刘备和关羽有关系,说明他们是一个团伙_科技向善-CSDN博客_sql团伙


广州某科技公司面试题 ——wang_Captain_DUDU的博客-CSDN博客

  • 1
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: OracleSYS_CONNECT_BY_PATH是一个聚合函数,它可以返回分层查询中从根节点到当前行的路径。在使用OracleCONNECT BY子句进行分层查询时,可以使用SYS_CONNECT_BY_PATH函数来返回从根节点到当前行的路径。例如,以下查询语句将查找名为“John”的员工及其所有下属的详细信息,并返回从根节点到当前行的路径: ``` SELECT employee_name, SYS_CONNECT_BY_PATH(employee_name, '/') AS path FROM employees WHERE manager_name = 'John' CONNECT BY PRIOR employee_name = manager_name; ``` 在此查询中,SYS_CONNECT_BY_PATH(employee_name, '/')将返回从根节点到当前行的路径,以斜杠分隔符分隔。例如,如果员工名为“Bob”的员工是“John”的下属,并且它们的直接上级是“Tom”,则该查询将返回以下结果: ``` employee_name | path --------------|----------------- John | /John Samantha | /John/Samantha Bob | /John/Bob Emily | /John/Emily ``` 其中,“/John”是根节点,“/John/Samantha”是根节点到Samantha的路径,“/John/Bob”是根节点到Bob的路径,“/John/Emily”是根节点到Emily的路径。 ### 回答2: SYS_CONNECT_BY_PATHOracle中的一个函数,它用于递归查询中连接子路径的功能。 具体来说,SYS_CONNECT_BY_PATH函数可以将递归查询的结果中的每一行连接起来,形成一个路径字符串。该函数的语法为: SYS_CONNECT_BY_PATH(column, separator) 其中,column是需要连接的列名,separator是连接每个列值的分隔符。 在使用SYS_CONNECT_BY_PATH函数时,通常会搭配使用CONNECT BY语句,来进行递归查询。CONNECT BY语句用于建立递归关系,指定父子关系的条件。 在每一层递归查询中,使用SYS_CONNECT_BY_PATH函数可以将当前行的column列值与前面层次的值连接起来形成路径。这样,每一行都可以得到一个以当前行为末端的完整路径。 例如,有一个员工表格,包含员工ID、姓名和上级ID三个列。要查询出每个员工的完整路径,可以使用以下语句: SELECT emp_id, emp_name, SYS_CONNECT_BY_PATH(emp_name, '/') AS emp_path FROM employee START WITH emp_id = 1 CONNECT BY PRIOR emp_id = superior_id; 以上语句会从员工表中以ID为1的员工为起点,根据上级ID建立递归关系,并使用SYS_CONNECT_BY_PATH函数连接每个员工的姓名,形成完整的路径。 最后的结果会包含每个员工的ID、姓名以及完整的路径,路径的格式为以"/"分隔每个员工的姓名。 这就是SYS_CONNECT_BY_PATH函数Oracle中的作用,通过连接子路径,可以更方便地处理递归查询的结果。 ### 回答3: SYS_CONNECT_BY_PATHOracle数据库中的一个内置函数,用于在使用CONNECT BY进行递归查询时,获取各级节点的路径信息。 在使用CONNECT BY进行递归查询时,可以通过使用SYS_CONNECT_BY_PATH函数,将每个节点的值与其路径连接起来,形成一个完整的路径字符串。该函数接受两个参数:要连接的值和用于分隔路径元素的分隔符。 下面是一个示例,假设有一个表employees,其中包含以下字段:emp_id、emp_name和manager_id。我们希望查询每个员工的上级经理,并将路径信息包含在结果中。 SELECT emp_name, SYS_CONNECT_BY_PATH(emp_name, '/') as path FROM employees CONNECT BY PRIOR emp_id = manager_id START WITH manager_id IS NULL; 该查询使用CONNECT BY进行递归查询,通过PRIOR关键字指定当前节点与上级节点的关联条件,START WITH关键字指定起始节点。 SYS_CONNECT_BY_PATH函数用于将emp_name值与路径分隔符'/'连接起来。例如,如果结果中的一行为"Alice", "/Bob",则表示"Alice"这个员工的上级经理为"Bob",路径为"/Bob"。 通过使用SYS_CONNECT_BY_PATH函数,我们可以方便地在递归查询的结果中获取节点的路径信息,并根据需要进行后续处理和分析。这在一些需要展示树状结构数据的场景下非常有用,例如组织架构、目录结构等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值