postgres递归查询

1、开发中我们经常会遇到数据库中的数据存在存在上小级的父子关系,如全国的省市信息,或者一个公司的部门信息等。

如果我们在查询的时候使用递归的方法直接将数据查询出来就可以避免我们在程序中在进行递归过滤数据了,下面我们以全国的省市为例,首先我们定义一张表,表的定义如下:

然后我们在其中放一些数据,数据如下:

递归有向上递归与向下递归,首先我们向下递归,查询河南省下面的所有记录,查询语句如下:

WITH RECURSIVE temptable AS (
           SELECT * FROM t_provinces WHERE pid = 2
         union   ALL
           SELECT t_provinces.* FROM t_provinces, temptable WHERE t_provinces.parentid = temptable.pid
         )
    SELECT * FROM temptable ORDER BY pid;

查询结果如图:


这样就将河南省下面的所有记录全部查了出来。

然后我们向上递归,查询栾川县的所有父记录。查询语句如下:

WITH RECURSIVE temptable AS (
           SELECT * FROM t_provinces WHERE pid = 28
         union   ALL
           SELECT t_provinces.* FROM t_provinces, temptable WHERE t_provinces.pid = temptable.parentid
         )
    SELECT * FROM temptable ORDER BY pid;
查询结果图如下:

这样就查询出来了栾川县的所有父记录。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值