oracle递归查询所有子节点

推荐 生活 2019-06-17 12:57:41 364

本文收集整理关于oracle递归查询所有子节点的相关议题,使用内容导航快速到达。

内容导航:

  • Q1:oracle 中怎样递归查询出子节点的最上层父节点,并
  • Q2:oracle 从子节点递归查询所有父节点
  • Q3:oracle 中怎样递归查询出子节点的最上层父节点,并且其父节点是自身
  • Q4:Oracle通过递归查询父子兄弟节点方法示例
  • Q1:oracle 中怎样递归查询出子节点的最上层父节点,并

    楼主您好 可以试试connect by prior替换成connect by nocycle priororacle 中怎样递归查询出子节点的最上层父节点,并
    wWw!.yiJItao.COm

    Q2:oracle 从子节点递归查询所有父节点

    select SYS_CONNECT_BY_PATH(列名,>) from 表名
    start wITh 列名=0000000001
    connect byprior列名(孩子列所有的列名)=列名(父列所有的列名)
    这个查出来的样式如下:
    000000000001>00000000>0000
    不知道是不是你想要的。

    Q3:oracle 中怎样递归查询出子节点的最上层父节点,并且其父节点是自身

    楼主您好
    可以试试connect by prior替换成connect by nocycle priorWw※w.YiJitaO.cOM

    Q4:Oracle通过递归查询父子兄弟节点方法示例

    前言

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

    方法如下:

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

    // 查询id为101的所有后代节点,包含101在内的各级父节点select t.* from SYS_ORG t start with id = 101 connect by parent_id = prior id

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

    select t.*from SYS_ORG twhere not exists (select 1 from SYS_ORG s where s.parent_id = t.id)start with id = 101connect by parent_id = prior id

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

    select t.*from SYS_ORG tstart with id = 401000501connect by prior parent_id = id

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

    select * from SYS_ORG twhere exists (select * from SYS_ORG s where t.parent_id=s.parent_id and s.id=401000501)

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

    with tmp as(select t.*, level leaffrom SYS_ORG tstart with t.parent_id = 0connect by t.parent_id = prior t.id)select *from tmpwhere leaf = (select leaf from tmp where id = 401000501);

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

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

    with tmp as(select t.*, level levfrom SYS_ORG tstart with t.parent_id = 0connect by t.parent_id = prior t.id)select b.*from tmp b,(select *from tmpwhere id = 401000501 and lev = 2) awhere b.lev = 1union allselect *from tmpwhere parent_id = (select distinct x.idfrom tmp x, --祖父tmp y, --父亲(select *from tmpwhere id = 401000501 and lev > 2) z --儿子where y.id = z.parent_id and x.id = y.parent_id);

    这里查询分成以下几步。

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

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

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

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

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

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

    总结

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

    您可能感兴趣的文章:深入sql oracle递归查询oracle SQL递归的使用详解oracle 使用递归的性能提示测试对比

    相关文章
    oracle如何备份数据库2019-01-30
    查看oracle 数据库时间2019-02-01
    oracle怎么创建数据库2019-02-06
    oracle新建临时表空间2019-02-16
    oracle创建数据库实例2019-02-20
    oracle11g建立表空间2019-02-21
    安装oracle数据库步骤2019-03-17
    oracle设置唯一键约束2019-03-20
    oracle和mysql分页区别2019-03-23
    oracle数据库的数据类型2019-03-26