龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 数据库类 > Oracle 技术 >

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

时间:2011-04-12 23:18来源:未知 作者:admin 点击:
分享到:
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数据库的递归查询就介绍这么多,谢谢各位一直以来的支持!

精彩图集

赞助商链接