postgresql使用with recursive完成迭代查询]

postgresql使用with recursive完成迭代查询

目录

正文

回到顶部

1.表结构

img

回到顶部

2.需求

查询某条记录的所有父亲节点,或者所有孩子节点。

回到顶部

3.向上查询(查询所有父亲节点)

注意,这里返回的记录包含自己。

sql如下:

[复制代码](javascript:void(0)?

1 WITH RECURSIVE res AS (
2   SELECT t1.* FROM t_code as t1  
3   WHERE t1.enable = 'true' and t1.id = '4'
4 
5   UNION 
6     SELECT t2.* from t_code as t2
7     INNER JOIN res as t3 ON t2.id = t3.parent_id
8     WHERE t2.enable = 'true'
9 )SELECT res.* from res

[复制代码](javascript:void(0)?

返回结果:

img

回到顶部

4.向下查询(查询所有孩子节点)

注意,这里返回的记录包含自己。

和上面的sql只有一个差别:

1 INNER JOIN res as t3 ON t3.id = t2.parent_id

sql如下:

[复制代码](javascript:void(0)?

1 WITH RECURSIVE res AS (
2   SELECT t1.* FROM t_code as t1  
3   WHERE t1.enable = 'true' and t1.id = '1'
4 
5   UNION 
6         SELECT t2.* from t_code as t2
7     INNER JOIN res as t3 ON t3.id = t2.parent_id
8     WHERE t2.enable = 'true'
9 )SELECT res.* from res

[复制代码](javascript:void(0)?

返回结果:

img

综上所述,可以将这段sql看做三个部分组成:(1)初始条件。(2)迭代条件。(3)将结果作为下一个迭代的初始条件。

其中迭代条件中,写作 INNER JOIN res as t3 ON t3.id = t2.parent_id 时,是表示上一次查询的结果(t3)是此时查询记录(t2)的父亲。即始终是用parent来查询children,为向下查询。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值