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

数据库 Oracle
本文通过对一段递归查询代码的分析来介绍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版报错的解决
责任编辑:赵鹏 来源: 博客园
相关推荐

2011-07-20 13:40:00

SQLite数据库查询数据

2011-07-20 14:32:59

SQLite数据库LIKE查询IN集合查询

2009-11-02 15:15:43

Oracle授予用户权

2010-04-02 15:04:14

Oracle递归查询

2010-04-06 10:32:12

Oracle递归查询

2010-04-26 14:43:17

Oracle递归条件查

2010-10-28 16:42:04

oracle多表查询

2009-07-15 13:41:00

JDBC实例

2011-07-19 09:18:50

Oracle级联删除

2011-07-20 14:57:47

SQLite数据库ORDER BYGROUP BY

2011-07-22 15:38:54

SQL Server数存储过程切割字符串

2011-07-20 12:55:17

SQLite数据库插入数据

2009-09-02 18:39:34

C#递归算法

2024-01-08 13:47:00

代码分析工具

2011-01-26 12:56:24

2009-11-19 11:23:08

Oracle重作日志

2011-07-20 17:02:51

Oracle数据库

2010-04-14 15:01:50

Oracle ASM

2011-09-08 13:41:53

Widget

2009-07-30 18:18:27

C#时间计算
点赞
收藏

51CTO技术栈公众号