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

摘要:
2.分级查询主要包括两个子句,一个是以开头,另一个是按连接。

1、简介:Oracle层次化查询是Oracle特有的功能实现,主要用于返回一个数据集,这个数据集存在树的关系(数据集中存在一个Pid记录着当前数据集某一条记录的Id)。

2、层次化查询主要包含两个子句,一个start with另一个是connect by。

start with:这个子句一般用于指定层次化查询的开始节点(也就是树的最顶级节点),找到最顶级节点,然后按照一定的规则开始查找其剩余的子节点

connect by:这个子句就是上面所说的规则,用于查找剩余子节点的规则

CREATE TABLE MENU
(    "ID" NUMBER, 
    "DATA" VARCHAR2(100), 
    "PID" NUMBER
) 
insert into MENU (id, data, pid)values (7, 'g', 3);
insert into MENU (id, data, pid)values (1, 'a', null);
insert into MENU (id, data, pid)values (2, 'b', null);
insert into MENU (id, data, pid)values (3, 'c', 2);
insert into MENU (id, data, pid)values (4, 'd', 2);
insert into MENU (id, data, pid)values (5, 'e', 4);
insert into MENU (id, data, pid)values (6, 'f', 1);

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

下面开始执行层次化查询,从PId为null的节点(该节点为根节点)开始递归查找,查找出所有的更节点下的子节点,构建出一个完整的树

select ID,DATA,nvl(TO_CHAR(PID),'NULL') from menu start with PID is NULL connect by prior ID=pid

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

代码解析:

(1)、start with PID is NULL  指定层次化查询的根节点,

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

红框内的两个节点为根节点,并开始遍历其余的节点。

(2)、connect by prior ID=pid  当前节点的PID等于上一层节点的ID,如果满足条件,就加入到树结果集中

指定遍历查找子节点的规则----->  这一过程是递归查找,会一层一层找下去,直到不符合这一规则,则查找停止。

3、实现上面结果集的另一种Sql实现

select ID,DATA,nvl(TO_CHAR(PID),'NULL') from menu start with (data='a' or data='b') connect by prior ID=PID

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

结论:根节点的定义比较灵活,但是(connect by)遍历子节点的规则,比较固定基本都是判断父节点和子节点的ID的,如果理解了这句话,层次化查询,差不多也就理解了!

4、  Oracle SQL 中的层次化查询会检测数据中是否存在回环(死循环),如果存在回环,则会抛出 ORA-01436: CONNECT BY loop in user data 的错误。如果在 connect by 后面加上 nocycle 则 产生回环的最后一层的节点会被删除。

如果数据中出现这种情况,产生了回环,那么在connect by 后面 加nocycle,节能

select ID,DATA,nvl(TO_CHAR(PID),'NULL') from menu start with (data='a' or data='b') connect by nocycle prior ID=PID 

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

just没有报错,有点郁闷,并没有删除,不知道哪里出了问题,但是至少不抱错了!!!

5、Oracle 还为层次化查询提供了一些伪列( Pseudo Column )。

(1)、CONNECT_BY_ISCYCLE 当这一行有一个子节点同时也是它的祖先节点时返回 1 ,否则返回 0 

(2)、CONNECT_BY_ISLEAF 当这一行是叶节点时返回 1 ,否则返回 0 。伪列 LEVEL 返回这一行在树中的层次,根为第一层。

(3)、CONNECT_BY_ROOT 查询操作符可以加在 connect by 之后的某个字段之前,表示获得这一行的根节点的该字段的值。

6、层次化查询还支持一个特殊的函数 SYS_CONNECT_BY_PATH , SYS_CONNECT_BY_PATH ( exp , char ),这个函数返回从根节点到这一行计算其中每个exp 表达式的值,并把它们连接成字符串,每个节点之间用 char 字符来分割。下面是一个例子。

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

这个函数很棒,可以考虑其他的数据库也实现这个方法,这样我们处理一个树结构就很方便了!!!

免责声明:文章转载自《oracle 层次化查询(生成菜单树等)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Python自带xml模块实现xpath查询带xmlns命名空间的xmlPyQt5复杂控件(树控件、选项卡控件(滚动条控件、多文档控件、停靠控件)下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Rsync+sersync部署

内核版本:2.6.32-431.el6.x86_64 系统采用最小化安装,系统经过了基本优化,selinux 为关闭状态,iptables 为无限制模式 源码包存放位置:/root Rsync 客户端+Sersync 服务器(SERSYNC),承担角色 MASTER,IP:172.16.100.3,主机名: rsync-client-sersync SE...

oracle创建表空间 扩展表空间文件 修改表空间自动增长

  1. 创建表空间 create tablespace SIRM2  datafile 'D:oracleproduct10.2.0oradataorclSIRM2.dbf' size 1024M --存储地址 初始大小1G autoextend on next 10M maxsize unlimited   --每次扩展10M,无限制扩展 EXTENT...

转:sqlplus使用总结

为什么我要使用sqlplus: SQLPLUS很多人用的并不多,在我观察周围来看,很多人都在使用PLSQL DEVELOPER,尤其是开发人员,更是如此,那学习SQLPLUS有啥好处呢?在我看来有如下三点1、当我们要在UNIX平台用SHELL访问数据库(如:做一些后台操作,定时任务等等),这个时候SQLPLUS是唯一选择。2、SQLPLUS 是ORACLE...

Oracle 11g服务器安装详细步骤

原出处:http://jingyan.baidu.com/article/363872eccfb9266e4aa16f5d.html 方法/步骤 1 大家可以根据自己的操作系统是多少位(32位或64位)的,到官网下载相应的安装程序,如下图所示。 有一点需要注意,Oracle的安装程序分成2个文件,下载后将2个文件解压到同一目录即可。...

Spring Data Redis入门示例:数据序列化 (四)

概述 RedisTemplate默认使用的是基于JDK的序列化器,所以存储在Redis的数据如果不经过相应的反序列化,看到的结果是这个样子的: 可以看到,出现了乱码,在程序层面上,不会影响程序的运行,但当出现数据错误,对数据进行排查时,就无从下手了。 序列化器 在Spring Data Redis中,用户自定义类型和存储数据之间的转换(反之亦然)由org...

ORACLE 判断首字母大小写问题

1.对判断的字段进行拆分 select  substr(要区分的字段,0,1)  from 表 ; 得到一个 首字母 2.对这个字符进行大小写判断 查出以小写字符为开头的 select  substr(要区分的字段,0,1)  from 表  where  substr(要区分的字段,0,1)=lower((substr(要区分的字段,0,1) )) ;...