oracle中的层级操作非常方便,在使用之后爱不释手,以前要实现该种数据查询操作,需要非常复杂的实现过程。在oracle中通过connect by可以实现前面的目的,通常情况下层级查询基本都能实现递归查询目的。下面是connect by的使用语法:

select [level], column, expr...
from table
[where condition]
start with condition
connect by [prior nodeCode1 = nodeCode2 | nodeCode1 = prior nodeCode2];

level :层级数,是个伪列。

start with :起始记录条件,是层级查询必要条件,支持支查询操作 。

connect by :表达层级关系,通过priore表示父层级/子层级,不支持子查询操作。

priore 关键字说明:

  • priore 在nodeCode1 前面表示 层级查询,priore在表示以start with 作为第一级,并查询该层级以下的所有层级。
  • priore 在nodeCode2前面表示以start with 作为第一级,并查询该层级以上的所有层级。

/*prior在等号前面查询*/

    select *
from ORGANIZE
where ORGTYPE = 1
start with code = '3502030039'
Connect By Prior code = PARENTCODE

上面语句查询结果:

1	厦门教育局
2 思明区教育局
3 湖里区教育局
4 海沧区教育局
5 集美区教育局
6 翔安区教育局
7 同安区教育局

/*prior在等号后面查询*/

    select *
from ORGANIZE
where ORGTYPE = 1
start with code = '3502030039'
Connect By code = Prior PARENTCODE

上面语句查询结果:

1	1	厦门教育局
2 2 福建省教育厅
3 3 中华人民共和国教育部

从上面两个查询结果很容易理解prior位置变化的作用。

oracle 其他层级操作函数

  • SYS_CONNECT_BY_PATH() 函数实现层级节点合并拼接操作
            select level,ORGNAME,sys_connect_by_path(ORGNAME,'>') [合并层级], prior ORGNAME [父节点]
from ORGANIZE
where ORGTYPE = 1
start with code = '3502030039'
Connect By Prior code = PARENTCODE ;

查询结果

1	1	厦门教育局	>厦门教育局
2 2 思明区教育局 >厦门教育局>思明区教育局 厦门教育局
3 2 湖里区教育局 >厦门教育局>湖里区教育局 厦门教育局
4 2 海沧区教育局 >厦门教育局>海沧区教育局 厦门教育局
5 2 集美区教育局 >厦门教育局>集美区教育局 厦门教育局
6 2 翔安区教育局 >厦门教育局>翔安区教育局 厦门教育局
7 2 同安区教育局 >厦门教育局>同安区教育局 厦门教育局
  • CONNECT_BY_ISLEAF特性

CONNECT_BY_ISLEAF特性可以用来判断该层级是否为叶节点,1表示叶节点.

           select level,prior  ORGNAME,sys_connect_by_path(ORGNAME,'<'),decode(connect_by_isleaf, 1,'叶节点', null) "节点类型"
from ORGANIZE
where ORGTYPE = 1
start with code = '3502030039'
Connect By Prior code = PARENTCODE

查询结果

1	1		        <厦门教育局
2 2 厦门教育局 <厦门教育局<思明区教育局 叶节点
3 2 厦门教育局 <厦门教育局<湖里区教育局 叶节点
4 2 厦门教育局 <厦门教育局<海沧区教育局 叶节点
5 2 厦门教育局 <厦门教育局<集美区教育局 叶节点
6 2 厦门教育局 <厦门教育局<翔安区教育局 叶节点
7 2 厦门教育局 <厦门教育局<同安区教育局 叶节点
  • CONNECT_BY_ROOT

CONNECT_BY_ROOT可用于读取根节点

            select
                level,ORGNAME ,prior  ORGNAME "父节点",
                sys_connect_by_path(ORGNAME,'<') "节点合并",
                decode(connect_by_isleaf, 1,'叶节点', null) "节点类型" ,
                connect_by_root  ORGNAME "根节点"
            from ORGANIZE         
            where ORGTYPE = 1         
            start with code = '3502030039'         
            Connect By Prior  code =  PARENTCODE   

查询结果

LEVEL    ORGNAME       父节点                节点合并         节点类型    根节点
1    厦门教育局        <厦门教育局        厦门教育局
2    思明区教育局    厦门教育局    <厦门教育局<思明区教育局    叶节点    厦门教育局
2    湖里区教育局    厦门教育局    <厦门教育局<湖里区教育局    叶节点    厦门教育局
2    海沧区教育局    厦门教育局    <厦门教育局<海沧区教育局    叶节点    厦门教育局
2    集美区教育局    厦门教育局    <厦门教育局<集美区教育局    叶节点    厦门教育局
2    翔安区教育局    厦门教育局    <厦门教育局<翔安区教育局    叶节点    厦门教育局
2    同安区教育局    厦门教育局    <厦门教育局<同安区教育局    叶节点    厦门教育局
  • order  siblings  by

oracle中的层级查询结果直接使用orader by 进行排序无法得到我们想要的结果,但可以通过order  siblings  by达到我们想要的既按照层级排序,又按照字段排序

oracle中的层级递归查询操作的更多相关文章

  1. oracle 中proc和oci操作对缓存不同处理

    oracle 中proc和oci操作对缓存不同处理

  2. 对oracle中date/timestamp的操作

    设置oracle中date的会话格式为 'yyyy-mm-dd hh24:mi:ss' alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss ...

  3. Oracle中日期时间的操作比较和加减-入门基础(转)

    Oracle关于时间/日期的操作     1.日期时间间隔操作 当前时间减去7分钟的时间 select sysdate,sysdate - interval '7' MINUTE from dual ...

  4. oracle中有关表的操作

    在Oracle中查看所有的表: select * from tab/dba_tables/dba_objects/cat; 看用户建立的表 : select table_name from user_ ...

  5. Oracle中快速查询和操作某个用户下的所有表数据信息

    一.禁止所有的外键约束 在pl/sql developer下执行如下语句:SELECT 'ALTER TABLE ' || table_name || ' disable CONSTRAINT ' | ...

  6. Oracle中字段的修改操作语法

      对字段操作 操作方法 更新字段名 alter table TABLE_NAME rename column column_old to column_new; 添加字段 alter table T ...

  7. Oracle “CONNECT BY” (层级递归查询)

    Oracle “CONNECT BY”是层次查询子句,一般用于树状或者层次结果集的查询.其语法是: ? 1 2 [ START WITH condition ] CONNECT BY [ NOCYCL ...

  8. ORACLE中用户等系统信息操作

    1.查看所有用户:select * from dba_users;   select * from all_users;   select * from user_users; 2.查看用户或角色系统 ...

  9. oracle 中关于null的操作

    空值 空值一般用NULL表示 一般表示未知的.不确定的值,也不是空格 一般运算符与其进行运算时,都会为空 空不与任何值相等 表示某个列为空用:IS NULL  不能使用COMM=NULL这种形式 某个 ...

随机推荐

  1. HDU 2993 MAX Average Problem dp斜率优化

    MAX Average Problem Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Othe ...

  2. [Codeforces Round #296 div2 D] Clique Problem 【线段树+DP】

    题目链接:CF - R296 - d2 - D 题目大意 一个特殊的图,一些数轴上的点,每个点有一个坐标 X,有一个权值 W,两点 (i, j) 之间有边当且仅当 |Xi - Xj| >= Wi ...

  3. 【Tools】Chrome 控制台不完全指南

    Chrome的开发者工具已经强大到没朋友的地步了,特别是其功能丰富界面友好的console,使用得当可以有如下功效: 更高「逼格」更快「开发调试」更强「进阶级的Frontender」 Bug无处遁形「 ...

  4. Spring REST

    前面介绍过Spring的MVC结合不同的view显示不同的数据,如:结合json的 view显示json.结合xml的view显示xml文档.那么这些数据除了在WebBrowser中用JavaScri ...

  5. jsp分页技术

    1.以下为分页类: import java.io.Serializable;  import java.util.List;    import org.apache.commons.lang.bui ...

  6. 有关Spring Batch

    在使用Spring Batch时,在无法实现StepListener的情况下,如何使用ExecutionContext呢. 解决办法,使用宣言@BeforeStep或@AfterStep.

  7. Eclipse下安装及配置maven项目管理工具

    ①eclipse下maven插件安装. 本地maven安装.环境变量配置完成后,打开eclipse,点击eclipse菜单栏Help->Eclipse Marketplace搜索关键字maven ...

  8. Oracle 插入超4000字节的CLOB字段的处理方法

    最近在做系统开发的时候需要想Oracle数据库插入超过4000字节的CLOB字段,在网上查询了N久才发现下面的解决方案,故留存以备后查. 我们可以通过创建单独的OracleCommand来进行指定的插 ...

  9. bzoj 3156 防御准备(斜率DP)

    3156: 防御准备 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 837  Solved: 395[Submit][Status][Discuss] ...

  10. [svn] 数据库操作残留,无法进行操作的解决方法

    WINDOWS环境下的解决方法: 1: 下载sqlite3数据库工具,放置于SVN的同级目录 2: CMD路径转移到Sqlite3目录 3: 残留操作选择: sqlite3 .svn/wc.db &q ...