Oracle通过递归查询父子兄弟节点方法示例
发表于:2024-10-21 作者:千家信息网编辑
千家信息网最后更新 2024年10月21日,前言说到Oracle中的递归查询语法,我觉得有一些数据库基础的童鞋应该都知道,做项目的时候应该也会用到,下面本文就来介绍下关于Oracle通过递归查询父子兄弟节点的相关内容,分享出来供大家参考学习,下
千家信息网最后更新 2024年10月21日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安全错误
数据库的锁怎样保障安全
我的世界真的要关服务器吗
软件开发中心化思想
福州通用服务器报价
小红书无法连接服务器请刷新
芊笔芯网络技术有限公司
网络安全支付法律
互联网科技项目编号
金蝶k3销售出库数据库表单
柔晶美软件开发
网络安全教育班会活动记录
许昌学软件开发
张北天气预报软件开发
网络安全主要问题与对策
大兴回收服务器报价单
酒店管理系统数据库课程
网络安全纪念日
软链接mysql数据库地址
千牛云服务器无法登录
短视频app软件开发平台
开源dhcp准入服务器
郑州网络安全科技馆的意义
吉林市翼搏网络技术
软件开发用户需求分析模板
安卓数据库服务器
数据库查看学生信息
数据库中的关系模型例子
网络安全主要问题与对策
网络安全教育重要性
关于网络安全给朋友的建议
网络安全观察哨