そのようなテーブルがあるとしましょう(SQL SERVER 2005)
pairID childID parentID
0 1 2
1 2 3
2 3 4
そして、このデータセットを返す CTE があります。
pairID childID parentID level
0 1 2 2
1 2 3 1
2 3 4 0
代わりにこの結果セットを取得できるように、最初の子 ID を保存するにはどうすればよいですか。
pairID childID parentID level
0 1 2 2
1 1 3 1
2 1 4 0
基本的に私がやっていることは、元の子IDを保持し、他の代わりにそれを返すことです...
これはこれまでの CTE クエリで、完全に機能します。
WITH TESTER AS (SELECT a.PairID,
a.ChildID,
a.ParentID,
0 AS Level
FROM
BusinessHierarchy AS a
LEFT OUTER JOIN BusinessHierarchy AS a2
ON a.ParentID = a2.ChildID
WHERE (a2.PairID IS NULL)
UNION ALL
SELECT b.PairID, b.ChildID, b.ParentID, oh.Level + 1 AS Level
FROM BusinessHierarchy AS b INNER JOIN
TESTER AS oh ON b.ParentID = oh.ChildID)
SELECT PairID, ChildID, ParentID, Level
FROM TESTER AS x
ORDER BY Level, ChildID, ParentID