没有CTE的Postgres / PADB中的递归自查询

时间:2015-08-06 13:59:48

标签: sql postgresql recursive-query self-join

我正在使用缺乏递归CTE的PADB / Postgres。我试图找到一种方法来编写递归自联接只使用常规连接/联合没有递归CTE。最简单的方法是什么?

我有一张这样的表:

PersonID | Initials | ParentID
1          CJ         NULL
2          EB         1
3          MB         1
4          SW         2
5          YT         NULL
6          IS         5

我希望能够获得仅与特定人员开始的层次结构相关的记录。所以如果我通过PersonID = 1请求CJ的层次结构,我会得到:

PersonID | Initials | ParentID
1          CJ         NULL
2          EB         1
3          MB         1
4          SW         2

对于EB,我会得到:

PersonID | Initials | ParentID
2          EB         1
4          SW         2

1 个答案:

答案 0 :(得分:0)

这是我能想到的最简单的解决方案。

select * from t where personid = '1' --needs replacement with personid you run for
union
select * from t where personid in (select personid from t where parentid = '1')
or parentid in (select personid from t where parentid = '1')

personid需要替换为查看层次结构所需的人。

SQL小提琴:http://sqlfiddle.com/#!15/f1201/1