项目上使用了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是子节点,相当于 父 -> 子 的查
本文介绍了在PostgreSQL中如何使用递归查询来查找指定节点的所有上级节点和下级节点。通过WITH RECURSIVE语句,分别展示了查询上级节点(c.c=t.p)和下级节点(c.p=t.c)的SQL示例,并强调了理解递归入口和条件的重要性。

1868

被折叠的 条评论
为什么被折叠?



