したがって、次のように構造化された2つのテーブルがあります。
CREATE TABLE #nodes(node int NOT NULL);
ALTER TABLE #nodes ADD CONSTRAINT PK_nodes PRIMARY KEY CLUSTERED (node);
CREATE TABLE #arcs(child_node int NOT NULL, parent_node int NOT NULL);
ALTER TABLE #arcs ADD CONSTRAINT PK_arcs PRIMARY KEY CLUSTERED (child_node, parent_node);
INSERT INTO #nodes(node)
VALUES (1), (2), (3), (4), (5), (6), (7);
INSERT INTO #arcs(child_node, parent_node)
VALUES (2, 3), (3, 4), (2, 6), (6, 7);
2つのノードがある場合、たとえば1と2とします。それらのルートノードのリストが必要です。この場合、1、4、および7になります。その情報を取得するためのクエリを作成するにはどうすればよいですか。
私はそれを書くことに挑戦しましたが、何らかの理由でCTEの再帰部分でLEFT結合を使用できないという問題に遭遇しました。これは、LEFTJOINの実行が許可された場合に機能するクエリです。
WITH root_nodes
AS (
-- Grab all the leaf nodes I care about and their parent
SELECT n.node as child_node, a.parent_node
FROM #nodes n
LEFT JOIN #arcs a
ON n.node = a.child_node
WHERE n.node IN (1, 2)
UNION ALL
-- Grab all the parent nodes
SELECT rn.parent_node as child_node, a.parent_node
FROM root_nodes rn
LEFT JOIN #arcs a -- <-- LEFT JOINS are Illegal for some reason :(
ON rn.parent_node = a.child_node
WHERE rn.parent_node IS NOT NULL
)
SELECT DISTINCT rn.child_node as root_node
FROM root_nodes rn
WHERE rn.parent_node IS NULL
クエリを再構築して必要なものを取得する方法はありますか?データを再構築することはできません。一時テーブルを避けたり、高価なことをしなければならないことを本当に望んでいます。
ありがとう、ラウル