一个Oracle递归查询的实例代码分析

Oracle数据库递归查询用途非常的广泛,我们做递归查询首先要定义好递归函数,以及它的参数和返回值,然后实现查询。本文通过一个代码的实例讲解介绍了这一过程,接下来我们就开始介绍。

一、树型表结构:

节点ID 上级ID 节点名称

二、公式:

 
 
 
  1. select 节点ID,节点名称,level  
  2.  
  3. from 表  
  4.  
  5. connect by prior 节点ID=上级节点ID  
  6.  
  7. start with 上级节点ID=节点值 

说明:

1、常见的树形结构为公司组织机构、地区……

2、求节点ID以上的结构,或以上的结构,将“节点ID=上级节点ID”左右顺序换一下即可。

3、Level为Oracle的特殊字段,表示“层”的意思。当前节点ID的下一层节点为“1”。

测试SQL:

说明1、求002以下(或以上)所有子节点和层次(动态:总是从1开始算),但不包括自身。

说明2、如果求002以上的节点,则“connect by prior topno=departno”,“=”两边的条件换位即可。

 
 
 
  1. select departno,departname,level  
  2.  
  3. from dept  
  4.  
  5. connect by prior departno=topno 
  6.  
  7. start with topno='002'; 

测试数据:

 
 
 
  1. create table Dept(  
  2.  
  3. DepartNO varchar2(10),  
  4.  
  5. DepartName varchar2(20),  
  6.  
  7. TopNo varchar2(10));  
  8.  
  9. insert into Dept values('001',' 董事会','0');  
  10.  
  11. insert into Dept values('002','总裁办 ','001');  
  12.  
  13. insert into Dept values('003','财务部 ','001');  
  14.  
  15. insert into Dept values('004','市场部 ','002');  
  16.  
  17. insert into Dept values('005','公关部 ','002');  
  18.  
  19. insert into Dept values('006','销售部 ','002');  
  20.  
  21. insert into Dept values('007','分销处 ','006');  
  22.  
  23. insert into Dept values('008','业务拓展处','004');  
  24.  
  25. insert into Dept values('009','销售科','007'); 

向前查,比如:

 
 
 
  1. select distinct departno,departname,level  
  2.  
  3. from dept  
  4.  
  5. connect by prior topno=departno 
  6.  
  7. start with  
  8.  
  9. departno='005'; 

那么其实是查005自身以及上级, 所以结果是005,002,001。

总结:写递归最关键的要定义出来递归函数,递归函数最关键的要定义出来它的参数和它的返回值。参数最重要,分析一下参数怎么去定义?这时候要分析递归的过程,递归过程什么样呢?根据它的id 找它的父id,根据它的父id 找到它的孩子,根据它的孩子再找到它的孩子。那么分析这个参数肯定是一个id,因为只有传进来id,才知道怎么去找这个id。

关于Oracle数据库的递归查询就介绍这么多,谢谢各位一直以来的支持!

【编辑推荐】

  1. 共享database独立Schema构建SAAS平台
  2. 利用Sql Server将Excel中的数据导入Oracle
  3. Oracle跟踪文件分析工具TKPROF使用简介
  4. 环境变量导致ASP.Net无法连接Oracle的一个案例
  5. PLSQL Developer8连接Oracle 10g X64版报错的解决

本文名称:一个Oracle递归查询的实例代码分析
标题网址:http://www.csdahua.cn/qtweb/news40/330290.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网