`
fyd222
  • 浏览: 103930 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

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

 
阅读更多

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

--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_conditionempno = mgr,即子节点的mgr等于父节点的empno,在此时mgr7839的记录

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 查询

分享到:
评论

相关推荐

    oracle中connect-by-prior用法,实战解决日期分解问题.docx

    Oracle数据库中的`CONNECT BY PRIOR`是一个强大的查询构造器,用于处理树形数据结构,尤其在组织层级、部门结构或者员工管理系统中非常常见。这个功能允许我们从一个或多个根节点开始,按照指定的规则遍历整个树结构...

    Oracle 实战SQL层次查询

    ### Oracle 实战SQL层次查询详解 #### 一、层次查询概念 层次查询,也被称为树型结构查询,是在SQL中最常见的功能之一。这种查询方式主要用于处理具有层级结构的数据,例如组织架构、产品分类等场景。在Oracle...

    数据库开发 Oracle数据库 SQL开发教程 第10章 层次查询(共17页).pdf

    在学习层次查询时,首先要理解自然树结构的概念,这通常指的是数据表中的一行数据可以有多个子行,而每个子行又有自己的子级,形成一个层次化的结构。例如,EMP表中的数据就展示了员工的上级-下级关系,形成了一个...

    工作中常用的sql--------------------------

    CONNECT BY PRIOR col5 = col6 GROUP BY col1, col2, col3; ``` **解析**: 这是一个复杂的查询示例,利用了窗口函数、字符串函数、树状遍历等功能。具体步骤如下: 1. 使用`RANK()`函数对每一组`col1`, `col2`, `...

    一种MySQL数据库SQL递归查询的研究与实现.pdf

    CONNECT BY PRIOR`子句直接支持递归查询,而SQL Server 2005及以上版本则利用公共表表达式(CTE)的递归调用来实现。POSTgreSQL同样支持CTE子查询进行递归。这些数据库允许在SQL语句中直接对子查询进行递归调用,...

    SQL语句 递归

    在Oracle中,递归查询主要通过`START WITH`和`CONNECT BY PRIOR`子句实现。 ### 二、递归查询的基本语法 递归查询的基本语法如下: ```sql SELECT column_name(s) FROM table_name START WITH condition CONNECT ...

    Oracle层次查询功能的剖析.pdf

    Oracle层次查询的语法包括`START WITH`和`CONNECT BY`两个关键字。`START WITH`指定层次数据的起始节点,即层次结构的根节点。`CONNECT BY`则定义了父节点与子节点之间的关系,用于遍历整个层次结构。此外,可以使用...

    00571 Oracle公司内部数据库培训资料-Les19_分级查询(PPT 16页).ppt

    Oracle数据库的分级查询是数据库管理中的一个重要概念,主要用于处理具有层级关系的数据,如组织结构、产品目录等。...通过掌握这些知识,数据库管理员和开发人员能够更有效地管理和查询层次化数据,提升工作效率。

    oracle层次查询

    `LEVEL`伪列表示从根节点开始的层级数,`START WITH MGR IS NULL`确保从最高级别的管理者开始查询,而`CONNECT BY PRIOR EMPNO = MGR`定义了父子关系。 #### 四、结果解析 查询结果展示了公司内部的管理层次,每一...

    oracle 的包,层次化查询和触发器视频教程

    Oracle提供了CONNECT BY子句,配合PRIOR关键字,用于构建查询树形结构数据的SQL语句。例如,你可以用它来查询公司的组织架构,找出每个员工的直接上级。层次化查询还可以通过START WITH子句指定查询的起始节点,以及...

    Oracle递归查询

    在Oracle数据库中,递归查询主要依赖于`START WITH`和`CONNECT BY PRIOR`两个关键语法。本文将详细介绍这些概念以及具体的使用方法。 #### 二、创建示例表 为了更好地理解Oracle中的递归查询,我们首先需要创建...

    ORACLE与SQLSERVER语法差异分析

    - 对于ORACLE,递归查询同样使用`WITH`子句和`CONNECT BY`关键字,但`PRIOR`关键字的位置不同,用来指定层次关系的方向。`START WITH`指定了递归开始的条件。 2. **行号**: - ORACLE使用`ROWNUM`来获取行号,它...

    Oracle+SQL精妙SQL语句讲解.txt

    CONNECT BY PRIOR RN = RN - 1 AND PRIOR ID = ID GROUP BY ID, NAME ORDER BY ID; ``` 此查询首先根据`TABLE1.ID`对数据进行分组,并按`NAME`排序,然后使用`ROW_NUMBER()`函数为每一组分配一个行号。之后使用`SYS...

    oracle prior

    Oracle 中的 Prior 子句是结构化查询中用的,基本语法是:select ... from tablename start with 条件 1 connect by 条件 2 where 条件 3;其中,条件 1 是根结点的限定语句,可以放宽限定条件以取得多个根结点,即多...

    高性能sql調整,適用oracle和系統開發人員學習

    在Oracle中,我们可以使用`CONNECT BY PRIOR`和`START WITH`子句来构建这样的查询。`CONNECT BY PRIOR`用于定义层级关系,`START WITH`则指定了查询的起始节点。 例如,要显示以工作号'002'为根的员工树型结构,...

    在ORACLE、MSSQL、MYSQL中树结构表递归查询的实现.pdf

    CONNECT BY子句通常配合START WITH子句使用,其中START WITH指定了递归的起点,而CONNECT BY用于定义父子关系。CONNECT BY子句中的PRIOR关键字用于表示层级之间的连接,它指向前一个步骤得到的列值。例如,如果当前...

    10.2.0.3版本 with改造递归查询

    Oracle数据库支持通过`CONNECT BY`和`START WITH`子句实现递归查询。递归查询通常用于处理层次结构数据,如组织结构、文件系统等。 ##### 2. WITH子句 WITH子句是Oracle SQL中的一个特性,它允许用户定义一个临时...

    资深DBA对Oracle编写规范的总结

    对于具有层次结构的数据,可以使用 CONNECT BY 和 START WITH 子句来进行树形查询。这种方式能够有效地展示数据之间的层级关系。 示例: ```sql SELECT LEVEL, ID, NAME FROM ORGANIZATION START WITH PARENT_ID ...

    oracle转DB2 对照

    - 注意点: Oracle使用 `START WITH` 和 `CONNECT BY` 进行层次查询,而DB2使用 `WITH RECURSIVE` 子句。 #### 9. 打印输出信息 - **Oracle** 和 **DB2** 都支持打印输出信息。 - Oracle示例: ```sql DBMS_...

    在db2和oracle中的对树的递归查询语句

    在数据存储中,树形结构是一种层次化的数据模型,它由节点(或称为记录)组成,每个节点可以有零个或多个子节点,这种结构通常用于表示组织关系、文件系统或层级分类等。 在Oracle中,对树的递归查询主要依赖于`...

Global site tag (gtag.js) - Google Analytics