甲骨文通过递归查询父子兄弟节点方法示例

  

  

说到Oracle中的递归查询语法,我觉得有一些数据库基础的童鞋应该都知道,做项目的时候应该也会用的到,下面本文就来介绍下关于Oracle通过递归查询父子兄弟节点的相关内容,分享出来供大家参考学习、下面话不多说了,来一起看看详细的介绍吧。

  

  

1,查询某节点下所有后代节点(包括各级父节点)

     //查询id为101的所有后代节点,包含在101内的各级父节点   选择t。从SYS_ORG * t id=?01”开始连接前由parent_id=id      

2,查询某节点下所有后代节点(不包含各级父节点)

        选择t。*   从SYS_ORG t   不存在(选择1从SYS_ORG s, s。parent_id=t.id)   从id=' 101 '   连接前由parent_id=id      

3,查询某节点所有父节点(所有祖宗节点)

        选择t。*   从SYS_ORG t   从id=' 401000501 '   连接通过之前parent_id=id      

4,查询某节点所有的兄弟节点(亲兄弟)

        select * from SYS_ORG t   存在(select * from SYS_ORG t.parent_id=年代。parent_id s.id=' 401000501 ')      

5,查询某节点所有同级节点(族节点),假设不设置级别字段

        与tmp (   选择t。*,水平叶   从SYS_ORG t   从t。parent_id=' 0 '   connect by t。parent_id=t.id之前)   select *   从tmp   叶=(选择叶子从tmp id=' 401000501 ');      

这里使用两个技巧,一个是使用了水平来标识每个节点在表中的级别,还有就是使与语用法模拟出了一张带有级别的临时表

  

, 6日查询某节点的父节点及兄弟节点(叔伯节点)

        与tmp (   选择t。*,列弗水平   从SYS_ORG t   从t。parent_id=' 0 '   connect by t。parent_id=t.id之前)   选择b。*   从tmp b (select *   从tmp   id=' 401000501 '和列弗=' 2 ')   在b。列弗=' 1 '   union all   select *   从tmp   parent_id=(选择不同x.id   从tmp x,祖父   tmp y,父亲   (选择*   从tmp   id=' 401000501 '和列弗祝辞' 2 ')z——儿子   在y。id=z。parent_id和x。id=y.parent_id);      

这里查询分成以下几步。
  

  

首先,将全表都使用临时表加上级别;
  

  

其次,根据级别来判断有几种类型,以上文中举的例子来说,有三种情况:
  

  

(1)当前节点为顶级节点,即查询出来的列弗值为1,那么它没有上级节点,不予考虑。
  

  

(2)当前节点为2级节点,查询出来的列弗值为2,那么就只要保证列弗级别为1的就是其上级节点的兄弟节点。
  

  

(3)其它情况就是3以及以上级别,那么就要选查询出来其上级的上级节点(祖父),再来判断祖父的下级节点都是属于该节点的上级节点的兄弟节点。
  

  

最后,就是使用联盟将查询出来的结果进行结合起来,形成结果集。

  

  

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。

甲骨文通过递归查询父子兄弟节点方法示例