Oracle层次化查询

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

--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.

时间: 2024-11-10 06:58:42

Oracle层次化查询的相关文章

oracle 层次化查询(生成菜单树等)

1.简介:Oracle层次化查询是Oracle特有的功能实现,主要用于返回一个数据集,这个数据集存在树的关系(数据集中存在一个Pid记录着当前数据集某一条记录的Id). 2.层次化查询主要包含两个子句,一个start with另一个是connect by. start with:这个子句一般用于指定层次化查询的开始节点(也就是树的最顶级节点),找到最顶级节点,然后按照一定的规则开始查找其剩余的子节点 connect by:这个子句就是上面所说的规则,用于查找剩余子节点的规则 CREATE TAB

●oracle——层次化查询

/* start with--以gb.no='110000'为根节点 connect by--指定父行和子行之间的关系 prior--该关键字之后的表达式将被作为查询中当前列的父列进行计算, 即该关键字后的列为父行的列.该关键字不限制是否在等号左侧 level--该列用来表示查询层次整型值 */ select level, gb.no, gb.name_full, gb.parent from sfsc.dr_area_gb gb start with gb.no = '110000' conn

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

--====================================================== --SQL基础-->层次化查询(START BY ... CONNECT BY PRIOR) --====================================================== 层次化查询,即树型结构查询,是SQL中经经常使用到的功能之中的一个,通常由根节点,父节点,子节点,叶节点组成,其语法例如以下: SELECT [LEVEL] ,column,ex

数据库编程3 Oracle 子查询 insert update delete 事务 回收站 字段操作 企业级项目案例

[本文谢绝转载原文来自http://990487026.blog.51cto.com] <大纲> 数据库编程3 Oracle 子查询 insert update delete 事务 回收站 字段操作 企业级项目案例 实验所用数据表 子查询,解决一步不能求解 查询工资比scott高的员工信息: 子查询知识体系搭建: 解释3,查询部门是sales的员工信息: 方法1:子查询 [方法2]:多表: 优化考虑: 解释4[select],只能放单行子查询 解释4[from] 考题:显示员工姓名,薪水 解释

【Oracle 常用查询】oracle表空间使用率统计查询

参考1 --查询表空间使用情况 SELECT Upper(F.TABLESPACE_NAME) "表空间名", D.TOT_GROOTTE_MB "表空间大小(M)", D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空间(M)", To_char(Round(( D.TOT_GROOTTE_MB - F.TOTAL_BYTES ) / D.TOT_GROOTTE_MB * 100, 2), '990.99') || '

Oracle 模糊查询方法

在这个信息量剧增的时代,如何帮助用户从海量数据中检索到想要的数据,模糊查询是必不可少的.那么在Oracle中模糊查询是如何实现的呢? 一.我们可以在where子句中使用like关键字来达到Oracle模糊查询的效果:在Where子句中,可以对datetime.char.varchar字段类型的列用Like关键字配合通配符来实现模糊查询,以下是可使用的通配符: (1)% :零或者多个字符,使用%有三种情况 字段 like '%关键字%'字段包含"关键字"的记录 字段 like '关键字%

Oracle分页查询语句的写法(转)

分页查询是我们在使用数据库系统时经常要使用到的,下文对Oracle数据库系统中的分页查询语句作了详细的介绍,供您参考. Oracle分页查询语句使我们最常用的语句之一,下面就为您介绍的Oracle分页查询语句的用法,如果您对此方面感兴趣的话,不妨一看. Oracle分页查询语句基本上可以按照本文给出的格式来进行套用.Oracle分分页查询格式: SELECT * FROM ( SELECT A.*, ROWNUM RN FROM (SELECT * FROM TABLE_NAME) A WHER

ORACLE 分页查询

Oracle之分页查询 Oracle的分页查询语句基本上可以按照本文给出的格式来进行套用. 分页查询格式: SELECT * FROM ( SELECT A.*, ROWNUM RN FROM (SELECT * FROM TABLE_NAME) A WHERE ROWNUM <= 40 ) WHERE RN >= 21 其中最内层的查询SELECT * FROM TABLE_NAME表示不进行翻页的原始查询语句.ROWNUM <= 40和RN >= 21控制分页查询的每页的范围.

Oracle生成查询包含指定字段名对应的所有数据表记录语句

应用场合:已知字段名字,查询数据库中所有数据表中包含该字段名的所有数据表 操作办法:指定字段名,数据库表用户,执行下面查询语句即可 --Oracle生成查询包含指定字段名对应的所有数据表记录语句 declare mycolumnname VARCHAR(255):='userid';--定义要查询的字段名变量,运行前修改成您要查询的字段名myownername VARCHAR(255):='system';--定义要查询的数据库用户名变量,运行前修改成您要查询的数据库用户名mystring NV