假设我有一个父子关系的表.
parent child 1 4 1 5 2 6 3 7 4 8 6 9 7 10 8 11
现在我有一个查询返回一个人的列表(例如1和2),我想找到他们所有的孩子,孙子等(在这种情况下:4,5,6,8,9,11).
我知道我可以使用通用表表达式递归搜索,但是我想知道是否可以创建一个sql语句来一次查找所有后代,而不必迭代输入集.
编辑:抱歉不够清楚.我正在寻找像:
SELECT {Hierarchical relation} from table where parent in (1,2)
这应该导致单个输出列,行为4,11.
我不再对产出的关系感兴趣,只是为多个家庭的家庭成员完整的一套.
解决方法
这里是
---- PlainTable ---- parent idElement (child) Null 1 1 4 1 5 2 6 3 7 4 8 6 9 7 10 8 11 WITH tableR (parent,idElement) AS ( -- Anchor member definition SELECT e.parent,e.idElement FROM PlainTable AS e WHERE parent in (1,2) UNION ALL -- Recursive member definition SELECT e.parent,e.idElement FROM PlainTable AS e INNER JOIN tableR AS d ON e.parent = d.idElement ) -- Statement that executes the CTE SELECT idElement FROM tableR --inner join to plain table by id if needed