oracle中的层级递归查询操作
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中的层级递归查询操作的更多相关文章
- oracle 中proc和oci操作对缓存不同处理
oracle 中proc和oci操作对缓存不同处理
- 对oracle中date/timestamp的操作
设置oracle中date的会话格式为 'yyyy-mm-dd hh24:mi:ss' alter session set nls_date_format='yyyy-mm-dd hh24:mi:ss ...
- Oracle中日期时间的操作比较和加减-入门基础(转)
Oracle关于时间/日期的操作 1.日期时间间隔操作 当前时间减去7分钟的时间 select sysdate,sysdate - interval '7' MINUTE from dual ...
- oracle中有关表的操作
在Oracle中查看所有的表: select * from tab/dba_tables/dba_objects/cat; 看用户建立的表 : select table_name from user_ ...
- Oracle中快速查询和操作某个用户下的所有表数据信息
一.禁止所有的外键约束 在pl/sql developer下执行如下语句:SELECT 'ALTER TABLE ' || table_name || ' disable CONSTRAINT ' | ...
- Oracle中字段的修改操作语法
对字段操作 操作方法 更新字段名 alter table TABLE_NAME rename column column_old to column_new; 添加字段 alter table T ...
- Oracle “CONNECT BY” (层级递归查询)
Oracle “CONNECT BY”是层次查询子句,一般用于树状或者层次结果集的查询.其语法是: ? 1 2 [ START WITH condition ] CONNECT BY [ NOCYCL ...
- ORACLE中用户等系统信息操作
1.查看所有用户:select * from dba_users; select * from all_users; select * from user_users; 2.查看用户或角色系统 ...
- oracle 中关于null的操作
空值 空值一般用NULL表示 一般表示未知的.不确定的值,也不是空格 一般运算符与其进行运算时,都会为空 空不与任何值相等 表示某个列为空用:IS NULL 不能使用COMM=NULL这种形式 某个 ...
随机推荐
- LightOj_1274 Beating the Dataset
题目链接 题意: 给一个文档, 这个文档由yes .no 组成, 共有s个byte, 共有n个yes.no. 假设yes的个数为yes_num, no的个数为no_num. 将这n个数进行排列, 对于 ...
- jQuery遍历对象、数组、集合实例
1.jquery 遍历对象 复制代码代码如下: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" ...
- [BZOJ 1016] [JSOI2008] 最小生成树计数 【DFS】
题目链接:BZOJ - 1016 题目分析 最小生成树的两个性质: 同一个图的最小生成树,满足: 1)同一种权值的边的个数相等 2)用Kruscal按照从小到大,处理完某一种权值的所有边后,图的连通性 ...
- ping命令找不到
重装系统后安装JDK了,网络一直不好,我ping了下,结果显示ping不是内部或者外部命令,在谷歌里百度了下,在环境变量的path后加上“;C:\Windows\System32”即可,果然有效哦. ...
- Redis3在CENTOS6上的安装配置
重温一下,这次找了个简单的安装. 测试过程很顺利哟. 参考URL: http://www.linuxidc.com/Linux/2015-07/119567.htm 一.介绍 redis在做数据库缓存 ...
- Silicon Labs电容式触摸感应按键技术原理及应用
市场上的消费电子产品已经开始逐步采用触摸感应按键,以取代传统的机械式按键.针对此趋势,Silicon Labs公司推出了内置微控制器(MCU)功能的电容式触摸感应按键(Capacitive Touch ...
- tomcat配置多实例
CATALINA_HOME环境变量不必配置,因为在startup.sh脚本里会指定CATALINA_HOME的位置. 配置tomcat多实例 首先是理解下原理:CATALINA_HOME指向安 ...
- 【狼】unity3d 怎样在一定时间连按两下键
public class DoubleClick : MonoBehaviour { ; void Update() { if (Input.GetKeyDown(KeyCode.D)) { if ( ...
- bzoj 1188 [HNOI2007]分裂游戏(SG函数,博弈)
1188: [HNOI2007]分裂游戏 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 733 Solved: 451[Submit][Status ...
- 4G来临 IT业转型之路当在不远
摘 要:4G商用未启,品牌营销争夺已经展开.目前,除了中国移动推出全新4G品牌“andM”之外,中国电信和中国联通均选择继续沿用3G的品牌. 4G商用未启,品牌营销争夺已经展开.12月10日,中国电信 ...