oracle通过id查询同一天生日的人,同一张表中,通过传入的id来获取所有关联的父id...

在很多数据库表的设计当中,在设计到树状结构数据时,并没有采用新建关联表,而是将所有的数据都放在的一张表中,即子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

108a8044f63367304da50ae94a39ec17.gif

de638df49f1d5a3342eecff86bcb011e.png

Myname_China

发布了11 篇原创文章 · 获赞 3 · 访问量 1万+

私信

关注

标签:start,pid,关联,prior,表中,节点,查询,id

来源: https://blog.csdn.net/Myname_China/article/details/104058480

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值