美图齐众专注资阳网站设计 资阳网站制作 资阳网站建设
资阳网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

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数据库之树形查询的代码示例
网页URL:http://www.zsjierui.cn/article/dphgpce.html

其他资讯