--======================================================

--SQL基础-->层次化查询(START BY ... CONNECT BY PRIOR)

--======================================================

层次化查询,即树型结构查询,是SQL中经常用到的功能之一,通常由根节点,父节点,子节点,叶节点组成,其语法如下:

SELECT [LEVEL] ,column,expression,...

FROM table_name

[WHERE where_clause]

[[START WITH start_condition] [CONNECT BY PRIOR prior_condition]];

LEVEL:为伪列,用于表示树的层次

start_condition:层次化查询的起始条件

prior_condition:定义父节点和子节点之间的关系

--使用start with ...connect by prior 从根节点开始遍历

SQL> select empno,mgr,ename,job from emp

2  start with empno = 7839

3  connect by prior empno = mgr;

EMPNO        MGR ENAME      JOB

---------- ---------- ---------- ---------

7839            KING       PRESIDENT

7566       7839 JONES      MANAGER

7788       7566 SCOTT      ANALYST

7876       7788 ADAMS      CLERK

7902       7566 FORD       ANALYST

7369       7902 SMITH      CLERK

7698       7839 BLAKE      MANAGER

7499       7698 ALLEN      SALESMAN

7521       7698 WARD       SALESMAN

7654       7698 MARTIN     SALESMAN

7844       7698 TURNER     SALESMAN

EMPNO        MGR ENAME      JOB

---------- ---------- ---------- ---------

7900       7698 JAMES      CLERK

7782       7839 CLARK      MANAGER

7934       7782 MILLER     CLERK

14 rows selected.

树型结构遍历过程(通过上面的查询来描述)

1).从根节点开始(即where_clause中的条件,如果为非根节点则分根节点作为根节点开始遍历,如上例empno = 7839)

2).遍历根节点(得到empno = 7839记录的相关信息)

3).判断该节点是否存在由子节点,如果则访问最左侧未被访问的子节点,转到),否则下一步

如上例中prior_condition为empno = mgr,即子节点的mgr等于父节点的empno,在此时mgr为7839的记录

4).当节点为叶节点,则访问完毕,否则,转到)

5).返回到该节点的父节点,转到)

--伪列level的使用

--注意connect by prior empno = mgr 的理解

--prior表示前一条记录,即下一条返回记录的mgr应当等于前一条记录的empno

SQL> select level,empno,mgr,ename,job from emp

2  start with ename = 'KING'

3  connect by prior empno = mgr

4  order by level;

LEVEL      EMPNO        MGR ENAME      JOB

---------- ---------- ---------- ---------- ---------

1       7839            KING       PRESIDENT

2       7566       7839 JONES      MANAGER

2       7698       7839 BLAKE      MANAGER

2       7782       7839 CLARK      MANAGER

3       7902       7566 FORD       ANALYST

3       7521       7698 WARD       SALESMAN

3       7900       7698 JAMES      CLERK

3       7934       7782 MILLER     CLERK

3       7499       7698 ALLEN      SALESMAN

3       7788       7566 SCOTT      ANALYST

3       7654       7698 MARTIN     SALESMAN

LEVEL      EMPNO        MGR ENAME      JOB

---------- ---------- ---------- ---------- ---------

3       7844       7698 TURNER     SALESMAN

4       7876       7788 ADAMS      CLERK

4       7369       7902 SMITH      CLERK

--获得层次数

SQL> select count(distinct level) "Level" from emp

2  start with ename = 'KING'

3  connect by prior empno = mgr;

Level

----------

4

--格式化层次查询结果(使用左填充* level - 1个空格)

SQL> col Ename for a30

SQL> select level,

2    lpad(' ',2 * level - 1) || ename as "Ename",

3    job

4  from emp

5  start with ename = 'KING'

6  connect by prior empno = mgr;

LEVEL Ename                          JOB

---------- ------------------------------ ---------

1  KING                          PRESIDENT

2    JONES                       MANAGER

3      SCOTT                     ANALYST

4        ADAMS                   CLERK

3      FORD                      ANALYST

4        SMITH                   CLERK

2    BLAKE                       MANAGER

3      ALLEN                     SALESMAN

3      WARD                      SALESMAN

3      MARTIN                    SALESMAN

3      TURNER                    SALESMAN

LEVEL Ename                          JOB

---------- ------------------------------ ---------

3      JAMES                     CLERK

2    CLARK                       MANAGER

3      MILLER                    CLERK

14 rows selected.

--从非根节点开始遍历(只需修改start with 中的条件即可)

SQL> select level,

2    lpad(' ',2 * level - 1) || ename as "Ename",

3    job

4  from emp

5  start with ename = 'SCOTT'

6  connect by prior empno = mgr;

LEVEL Ename                          JOB

---------- ------------------------------ ---------

1  SCOTT                         ANALYST

2    ADAMS                       CLERK

--从下向上遍历(交换connect by prior中的条件即可,使用mgr = empno)

--注意connect by prior mgr = empno 的理解
    --prior表示前一条记录,即下一条返回记录的empno应当等于前一条记录的mgr

SQL> select level,

2    lpad(' ',2 * level - 1) || ename as "Ename",

3    job

4  from emp

5  start with ename = 'SCOTT'

6  connect by prior mgr = empno;

LEVEL Ename                          JOB

---------- ------------------------------ ---------

1  SCOTT                         ANALYST

2    JONES                       MANAGER

3      KING                      PRESIDENT

--从下向上遍历(也可以将prior置于等号右边,得到相同的结果)

SQL> select level,

2    lpad(' ',2 * level - 1) || ename as "Ename",

3    job

4  from emp

5  start with ename = 'SCOTT'

6  connect by empno = prior mgr;

LEVEL Ename                          JOB

---------- ------------------------------ ---------

1  SCOTT                         ANALYST

2    JONES                       MANAGER

3      KING                      PRESIDENT

--从层次查询中删除节点和分支

SQL> select level,

2    lpad(' ',2 * level - 1) || ename as "Ename"

3    ,job

4  from emp

5  where ename != 'SCOTT'    --通过where子句来过滤SCOTT用户,但SCOTT的下属ADAMS并没有过滤掉

6  start with empno = 7839

7  connect by prior empno = mgr;

LEVEL Ename                JOB

---------- -------------------- ---------

1  KING                PRESIDENT

2    JONES             MANAGER

4        ADAMS         CLERK

3      FORD            ANALYST

4        SMITH         CLERK

2    BLAKE             MANAGER

3      ALLEN           SALESMAN

3      WARD            SALESMAN

3      MARTIN          SALESMAN

3      TURNER          SALESMAN

3      JAMES           CLERK

LEVEL Ename                JOB

---------- -------------------- ---------

2    CLARK             MANAGER

3      MILLER          CLERK

13 rows selected.

--通过将过滤条件由where 子句的内容移动到connect by prior 子句中过滤掉SCOTT及其下属

SQL> select level,

2    lpad(' ',2 * level - 1) || ename as "Ename"

3    ,job

4  from emp

5  start with empno = 7839

6  connect by prior empno = mgr and ename != 'SCOTT';

LEVEL Ename                JOB

---------- -------------------- ---------

1  KING                PRESIDENT

2    JONES             MANAGER

3      FORD            ANALYST

4        SMITH         CLERK

2    BLAKE             MANAGER

3      ALLEN           SALESMAN

3      WARD            SALESMAN

3      MARTIN          SALESMAN

3      TURNER          SALESMAN

3      JAMES           CLERK

2    CLARK             MANAGER

LEVEL Ename                JOB

---------- -------------------- ---------

3      MILLER          CLERK

12 rows selected.

--在层次化查询中增加过滤条件或使用子查询

SQL> select level,

2    lpad(' ',2 * level - 1) || ename as "Ename"

3    ,job

4  from emp

5  where sal > 2500

6  start with empno = 7839

7  connect by prior empno = mgr

8  ;

LEVEL Ename                JOB

---------- -------------------- ---------

1  KING                PRESIDENT

2    JONES             MANAGER

3      SCOTT           ANALYST

3      FORD            ANALYST

2    BLAKE             MANAGER

SQL> select level,

2    lpad(' ',2 * level - 1) || ename as "Ename"

3    ,job

4  from emp

5  where sal > (select avg(sal) from emp)

6  start with empno = 7839

7  connect by prior empno = mgr ;

LEVEL Ename                JOB

---------- -------------------- ---------

1  KING                PRESIDENT

2    JONES             MANAGER

3      SCOTT           ANALYST

3      FORD            ANALYST

2    BLAKE             MANAGER

2    CLARK             MANAGER

6 rows selected.

更多参考:

Oracle 数据库实例启动关闭过程

Oracle 10g SGA 的自动化管理

使用OEM,SQL*Plus,iSQL*Plus 管理Oracle实例

Oracle实例和Oracle数据库(Oracle体系结构)

SQL 基础-->常用函数

SQL基础-->过滤和排序

SQL 基础-->SELECT 查询

SQL基础-->层次化查询(START BY ... CONNECT BY PRIOR)[转]的更多相关文章

  1. SQL基础-->层次化查询(START BY ... CONNECT BY PRIOR)

    --====================================================== --SQL基础-->层次化查询(START BY ... CONNECT BY ...

  2. oracle递归层级查询 start with connect by prior

    递归层级查询:start with connect by prior  以部门表作为解析 表结构:dept{id:'主键',name:'部门名称',parent_id:'父亲id'} select * ...

  3. SQL基础-子查询&EXISTS&UNION

    一.子查询 1.使用子查询作为计算字段 子查询:嵌套在其他查询中的查询 现在有两个表,student表和teacher表 创建teacher表,并插入数据: CREATE TABLE `teacher ...

  4. SQL基础--> 约束(CONSTRAINT)

    --============================= --SQL基础--> 约束(CONSTRAINT) --============================= 一.几类数据完 ...

  5. 2-14-1 MySQL基础语句,查询语句

    一. SQL概述 结构化查询语言(Structured Query Language)简称SQL 1. 它是一种特殊目的的编程语言 2. 它还是一种数据库查询和程序设计语言 (用于存取数据以及查询.更 ...

  6. 【SQL】CONNECT BY 层次化查询

    层次化查询,顾名思义就是把查询结果有层次的呈现出来.层次化查询结果类似于树状结构,最顶端的是“根节点”,下面是“父节点”,没有子节点的是“叶节点”. 为了让一个或多个表具有层次关系,必须使用相关的字段 ...

  7. SQL 高级查询(层次化查询,递归)

    SQL 高级查询 前面我们写了一下 SQL 的极简入门,今天来说点高级查询.没看到的朋友可以点击下面链接查看. 1 小时 SQL 极速入门(一) 1 小时 SQL 极速入门(二) 1 小时 SQL 极 ...

  8. SQL Fundamentals: 子查询 || 行列转换(PIVOT,UNPIVOT,DECODE),设置数据层次(LEVEL...CONNECT BY)

    SQL Fundamentals || Oracle SQL语言 子查询(基础) 1.认识子查询 2.WHERE子句中使用子查询 3.在HAVING子句中使用子查询 4.在FROM子句中使用子查询 5 ...

  9. [SQL] SQL 基础知识梳理(二) - 查询基础

    SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...

随机推荐

  1. node.js + socket.io实现聊天室一

    前段时间,公司打算在社区做一个聊天室.决定让我来做.本小白第一次做聊天类功能,当时还想着通过ajax请求来实现.经过经理提示,说试试当前流行的node.js 和socket.io来做.于是就上网学习研 ...

  2. phpmyadmin开启远程服务器连接

     1.修改 braries/config.default.php,将 $cfg['AllowArbitraryServer'] 的值由 false 改成 true. 2.有其他需求的也可以自己在这里修 ...

  3. Yoga安装Ubuntu后,wifi和亮度调节问题

    http://askubuntu.com/questions/318608/lenovo-yoga-13-realtek-wireless-driver/358479#358479 http://it ...

  4. BZOJ 1877 晨跑

    http://www.lydsy.com/JudgeOnline/problem.php?id=1877 思路:拆点费用流,答案就是最大流量和最小费用. #include<algorithm&g ...

  5. Powershell 快捷键

    Powershell的快捷键和cmd,linux中的shell,都比较像. ALT+F7 清除命令的历史记录PgUp PgDn 显示当前会话的第一个命令和最后一个命令Enter 执行当前命令End 将 ...

  6. ftp和http转参数的使用(转)

    浏览器因特网资源:URL是浏览器寻找信息时所需的资源位置,通过URL,应用程序才能找到并使用共享因特网上大量的数据资源. 大部分URL都遵循一种标准的格式: ①HTTP协议(http://或者http ...

  7. (转)open和fopen的区别:

    fopen与open的区别 open和fopen的区别: 1.缓冲文件系统缓冲文件系统的特点是:在内存开辟一个“缓冲区”,为程序中的每一个文件使用,当执行读文件的操作时,从磁盘文件将数据先读入内存“缓 ...

  8. Fish’s mission

    Fish’s mission 也就是求一个坐标到各个食堂的距离和最小,随机化做应该也是可以的.标程用的方法是利用单调性,不断尝试四个方向,二分的方法做的.实际上就是蚁群退火算法. #include & ...

  9. wikioi1191 数轴染色

    题目描述 Description 在一条数轴上有N个点,分别是1-N.一开始所有的点都被染成黑色.接着 我们进行M次操作,第i次操作将[Li,Ri]这些点染成白色.请输出每个操作执行后 剩余黑色点的个 ...

  10. Walls and Gates 解答

    Question You are given a m x n 2D grid initialized with these three possible values. -1 - A wall or ...