Oracle数据库之树形查询的代码示例

Oracle数据库树形查询是本文我们主要要介绍的内容,包括树形查询的基本语法、构造环境、根节点遍历子节点以及子节点向根节点追溯,接下来就让我们一起来了解一下这部分内容吧。

基本语法:

 

 
 
 
  1. select...from tabename start with cond1 connect by  prior cond2 where cond2 

 

注意:

cond1是根节点的限定语句。

cond2是连接条件,其中prior表示上一条记录,指该记录的父亲是上一条记录。

cond3是过滤条件。

构造环境:

 

 
 
 
  1. create table Family(  
  2. id integer,  
  3. parentid integer,  
  4. name varchar2(50)  
  5. )  
  6. insert into family values(0,0,'a')  
  7. insert into family values(1,0,'b')  
  8. insert into family values(2,1,'c')  
  9. insert into family values(3,1,'d')  
  10. insert into family values(4,1,'e')  
  11. insert into family values(5,1,'f') 

 

通过根节点遍历子节点

例如:查询父亲等于1的所有子的信息

 
 
 
  1. select * from family start with parentid=1 connect by prior id=parentid 

 

通过子节点向根节点追溯

例如:

 

 
 
 
  1. select * from family start with id=5 connect by prior parentid=id 

 

注:如果报ORA-01436:用户数据库中的coonect by循环,则将第一条数据中的parentid改为null,否则loop循环找parentid就找不到了!

扩展:通过level 关键字查询所在层次

select t.*,level from family t start with parentid=1 connect by prior id=parentid

注意:表必须用别名。

关于Oracle数据库的树形查询的知识就介绍到这里了,如果您想了解更多Oracle数据库的知识,可以看一下这里的文章:http://database./oracle/,相信一定可以带给您收获的!

【编辑推荐】

  1. 适合初学者的MySQL学习笔记之库操作示例
  2. 适合初学者的MySQL学习笔记之表操作示例
  3. 适合初学者的MySQL学习笔记之MySQL管理心得
  4. 适合初学者的MySQL学习笔记之MySQL查询示例
  5. 适合初学者的MySQL学习笔记之管理员常用操作总结

分享标题:Oracle数据库之树形查询的代码示例
本文地址:http://www.mswzjz.cn/qtweb/news39/335639.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

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