postgresql 递归查询小记

本文介绍了在PostgreSQL中如何使用递归查询来查找指定节点的所有上级节点和下级节点。通过WITH RECURSIVE语句,分别展示了查询上级节点(c.c=t.p)和下级节点(c.p=t.c)的SQL示例,并强调了理解递归入口和条件的重要性。
摘要由CSDN通过智能技术生成

项目上使用了postgresql,在查询一个字典表时需要递归查询,把别人的sql 拷过来, 改了改发现不对,于是研究了一下如下

有一个category 表数据如下,c是节点id, p是父节点id,最顶层父节点id是r 

需求:需要根据给定的 节点id查出他的所有的上级节点 或者 子节点

1.根据给定的 节点id查出他的所有的上级节点

sql 如下:

with RECURSIVE  t as(
    select * from category where c= 'r11' 
    union 
    select c.* from category c,t where  c.c= t.p
)

select  * from t

查询结果

注意这个地方: where  c.c= t.p       只要记住 c.c = t.p 看做c是子节点,p是父节点, 相当于 子 -> 父 的查

2.根据给定的 节点id查出他的所有的下级节点

sql 如下:

with RECURSIVE  t as(
    select * from category where c= 'r11' 
    union 
    select c.* from category c,t where  c.p= t.c
)

select  * from t

查询结果:

注意这个地方: where  c.p= t.c      只要记住 c.p= t.c 是递归的条件, 看做p是父节点,c是子节点,相当于 父 -> 子 的查

总结: select * from category where c= 'r11'  是递归的入口, 只要注意入口和递归条件,还有递归方向就ok

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值