同一张表中,通过传入的id来获取所有关联的父id

本文介绍在Oracle数据库中如何使用递归查询处理树状结构数据,通过具体SQL语句展示如何通过父ID查询所有子ID,以及通过子ID查询所有父ID的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在很多数据库表的设计当中,在设计到树状结构数据时,并没有采用新建关联表,而是将所有的数据都放在的一张表中,即子id与父id共存于一条数据当中。

本文就oracle举例而言:

在这里,我们可以用递归查询的sql来处理:

select a.*,level  from  表名 a start  with 条件1  connnect by prior 条件2  where  条件3

例:

(1)、通过父id查询所有的子id
select id from sc_org start with pid ='0' connect by prior id = pid;

(2)、通过子id查询所有的父id
select pid from sc_org start with id ='1049692015' connect by prior pid = id;

1、start with :后面的条件表示递归的起始点。(从pid或id为多少时开始查)

2、connect by 条件2:表示递归时前后两条数据的关联关系

3、prior的位置决定了递归时的具体关系或者说是决定了查询时的检索顺序

      prior id = pid   可以理解为当前节点的id等于下一个节点的pid

      prior pid = id   可以理解为当前节点的pid等于下一个节点的id

4、level关键字表示层次: 可通过level 关键字表示查询结果所在层次,根节点的层号为1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Myname_China

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值