Oracle通过递归查询父子兄弟节点方法示例
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,前言说到Oracle中的递归查询语法,我觉得有一些数据库基础的童鞋应该都知道,做项目的时候应该也会用到,下面本文就来介绍下关于Oracle通过递归查询父子兄弟节点的相关内容,分享出来供大家参考学习,下
千家信息网最后更新 2025年11月07日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') awhere b.lev = '1'union allselect *from tmpwhere 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将查询出来的结果进行结合起来,形成结果集。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
节点
查询
级别
兄弟
上级
就是
内容
后代
祖父
学习
递归
情况
结果
语法
参考
方法
父子
上文
下级
两个
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
腾讯个人信息服务器在哪里
郴州正规软件开发价格
学信网数据库百度云下载
网络安全法自几日起实施
dell1900服务器硬盘阵列
湖南信息网络安全局
网络安全ppt模板
网络安全用什么技术最好
win10更新数据库顺怀
网络技术三级很容易吗
崇明区数据软件开发直销价格
信息网络技术的发特点
运行安全属于网络安全吗
全球科研项目数据库支持几种语言
舟山跑腿app软件开发费用
山东嵌入式软件开发公司
数据库管理技术的发展进程
定海网络安全防护
通信和网络技术具体事例
建立中国的脚型数据库
网络安全手指操
嵌入式软件开发的技术要求
数据库系统原理题库及答案
软件开发过程管理工具使用
中国人寿网络安全保险
网络安全的帆船模型
数据库建库的代码
云服务器服务器上用的系统
阿拉德之怒服务器是不是通用的
四川正规软件开发服务参考价格