postgresql 递归查询小记
项目上使用了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
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
