博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
oracle中 connect by prior 递归算法
阅读量:6092 次
发布时间:2019-06-20

本文共 1624 字,大约阅读时间需要 5 分钟。

有时候在界面常可以看到一种树形结构的案例:
  那么在数据库中是怎么设计的呢?
  给一个案例:
    
create table Employee(  parent_id int,--这个作为关联本身的父类节点   child_id int,   name varchar2(20) )insert into  employee values(1,2,'第2个');insert into  employee values(1,3,'第3个');insert into  employee values(2,4,'第4个');insert into  employee values(2,5,'第5个');insert into  employee values(3,6,'第6个');insert into  employee values(3,7,'第7个');insert into  employee values(4,8,'第8个');insert into  employee values(4,9,'第9个');insert into  employee values(5,10,'第10个');insert into  employee values(5,11,'第11个');insert into  employee values(8,12,'第12个');insert into  employee values(8,13,'第13个');

 

这是一个有上面设计而得的二叉树

 

 

从网上得知Oracle中start with...connect by prior子句用法 connect by 是可以用做查询数结构,而其基本语法是:
select ... from tablename start with 条件1
connect by 条件2
where 条件3;(这个条件不能放在末尾,要放在表名之后,否则会报错)
所以
例:

(1)select * from employee start with child_id=5 connect by prior parent_id=child_id

(2)select * from employee start with child_id=2 connect by prior child_id=parent_id

结果(1)

结果(2)

     简单说来是将一个树状结构存储在一张表里,比如一个表中存在两个字段:
  child_id,parent_id那么通过表示每一条记录的parent是谁,就可以形成一个树状结构。
     用上述语法的查询可以取得这棵树的所有记录。
     其中:
     条件1 是根结点的限定语句,当然可以放宽限定条件,以取得多个根结点,实际就是多棵树。
     条件2 是连接条件,其中用PRIOR表示上一条记录,比如 CONNECT BY PRIOR child_id= parent_id 就是说上一条记录的org_id 是本条记录的parent_id,即本记录的父亲是上一条记录。
     这个prior靠近哪边就往哪边查,如第(1)种情况就是父类方向查,第(2)种情况就是向子类方向查
     条件3 是过滤条件,用于对返回的所有记录进行过滤。
  
     简单介绍如下:
     早扫描树结构表时,需要依此访问树结构的每个节点,一个节点只能访问一次,其访问的步骤如下:
     第一步:从根节点开始;
     第二步:访问该节点;
     第三步:判断该节点有无未被访问的子节点,若有,则转向它最左侧的未被访问的子节,并执行第二步,否则执行第四步;
     第四步:若该节点为根节点,则访问完毕,否则执行第五步;
     第五步:返回到该节点的父节点,并执行第三步骤。
     总之:扫描整个树结构的过程也即是二叉树的中序遍历树的过程。

转载于:https://www.cnblogs.com/yaobolove/p/5804396.html

你可能感兴趣的文章
一个很好的幻灯片效果的jquery插件--kinMaxShow
查看>>
微信支付签名配置正确,但返回-1,调不出支付界面(有的手机能调起,有的不能)...
查看>>
第二周例行报告
查看>>
DataTable - the existing record can not be merged,just be added
查看>>
Html5最简单的游戏Demo——Canvas绘图的骰子
查看>>
-bash: mysql: command not found 解决办法
查看>>
MySQL密码过期策略
查看>>
UMDF
查看>>
[置顶] CSS禅意花园——CSS设计的绝美境界
查看>>
Git总结
查看>>
7-21测试
查看>>
周鸿祎:如何成为一名优秀的产品经理?
查看>>
项目使用Entity Framework用到的公共操作方法基类(Repository)及其使用 (转载)
查看>>
《Python 学习手册4th》 第十七章 作用域
查看>>
Python爬虫学习==>第三章:Redis环境配置
查看>>
JS与AS通信-转
查看>>
JS中正则匹配开头不带空格,结尾也不带空格的字符串
查看>>
Maximal Rectangle
查看>>
windows下如何修改远程登录端口
查看>>
UVA 10603 Fill
查看>>