zoukankan      html  css  js  c++  java
  • 时髦称呼:SQL递归"语法糖"的用法

    Oracle函数sys_connect_by_path 详解

    语法:
    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;

    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的员工 ‘>’与‘/’只是一个输出格式

    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/shulmblogs/archive/2011/09/29/2195236.html

  • 相关阅读:
    Linux基础命令sude(禁止root用户登录,使用普通用户登录,并且普通用户能够免密的切换到root用户)
    Linux基础命令sudo(sudo如何设置组?)
    Linux基础命令sudo(如何向用户提权?)
    Linux基础命令su(su命令如何切换用户?)
    Linux用户提权知识点及用户工作环境相关文件
    Linux基础命令groupdel(如何删除用户组?)
    Linux基础命令groupmod(如何修改用户组?)
    Linux基础命令groupadd(如何创建用户组?)
    Linux如何管理用户组?
    Linux如何设置更复杂的密码?
  • 原文地址:https://www.cnblogs.com/mylive/p/15162800.html
Copyright © 2011-2022 走看看