项目上使用了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是子节点,相当于 父 -> 子 的查