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

 更新时间:2018年01月14日 14:15:58   作者:dahaihh  
这篇文章主要给大家介绍了关于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 t
 where not exists (select 1 from SYS_ORG s where s.parent_id = t.id)
 start with id = '101'
connect by parent_id = prior id

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

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

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

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

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

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

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

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

with tmp as(
 select t.*, level lev
 from SYS_ORG t
 start with t.parent_id = '0'
 connect by t.parent_id = prior t.id) 
select b.*
from tmp b,(select *
   from tmp
   where id = '401000501' and lev = '2') a
where b.lev = '1'
union all
select *
from tmp
where parent_id = (select distinct x.id
    from tmp x, --祖父
      tmp y, --父亲
      (select *
      from tmp
      where 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将查询出来的结果进行结合起来,形成结果集。

总结

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

相关文章

  • Oracle收购TimesTen 提高数据库软件性能

    Oracle收购TimesTen 提高数据库软件性能

    Oracle收购TimesTen 提高数据库软件性能...
    2007-03-03
  • RAC cache fusion机制实现原理分析

    RAC cache fusion机制实现原理分析

    本文将详细介绍RAC cache fusion机制实现原理,需要了解更多的朋友可以参考下
    2012-12-12
  • oracle数据库sql的优化总结

    oracle数据库sql的优化总结

    自己对oracle sql的一些优化总结,特分享下,方便需要的朋友
    2013-08-08
  • Oracle CBO优化模式中的5种索引访问方法浅析

    Oracle CBO优化模式中的5种索引访问方法浅析

    这篇文章主要介绍了Oracle CBO优化模式中的5种索引访问方法浅析,包含索引唯一扫描、索引范围扫描、索引全扫描、索引跳跃扫描、索引快速全扫描等内容,需要的朋友可以参考下
    2014-07-07
  • Oracle之TO_DATE用法详解

    Oracle之TO_DATE用法详解

    这篇文章主要介绍了Oracle之TO_DATE用法详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • db2与oracle的sql语句有什么不同

    db2与oracle的sql语句有什么不同

    Oracle和DB2都是关系型数据库管理系统(RDBMS),但它们的设计理念、特性及性能等方面存在一些显著的差异,本文将详细比较Oracle和DB2,帮助企业和数据库管理员了解这两个系统各自的优势和局限性,并指导用户根据自己的业务需求作出合适的选择
    2024-02-02
  • oracle 字符串转成行

    oracle 字符串转成行

    oracle 将以逗号隔开的字符串'85,86,87' 转成行
    2009-06-06
  • 浅谈Oracle 11g 发行版2 新安装后关于登录的一些基本操作

    浅谈Oracle 11g 发行版2 新安装后关于登录的一些基本操作

    oracle 11g的两个不同版本。11g刚发行时,是11g第一版,简称11.1,现在有个11g第二版,在功能上有了更多的改进,简称11.2。本文给大家介绍Oracle 11g 发行版2 新安装后关于登录的一些基本操作,需要的朋友可以参考下
    2015-10-10
  • Oracle实现透明数据加密的代码示例

    Oracle实现透明数据加密的代码示例

    透明数据加密(TDE)是一种用于保护数据库中静态数据的加密技术,TDE通过自动加密数据库文件和日志文件,确保数据在磁盘上是加密的,从而防止未经授权的访问,以下以 Microsoft SQL Server 为例,实现 TDE 的步骤和代码示例,需要的朋友可以参考下
    2024-09-09
  • 修改ORACLE数据库密码有效期的方法

    修改ORACLE数据库密码有效期的方法

    这篇文章主要介绍了修改ORACLE数据库密码有效期的方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-09-09

最新评论