with句内でT1を使用しており、WITH内の句が完了した後にT1が宣言されているため、指定されたクエリはどのように正しいですか。
WITH T1(Emp,Manager,Salary) AS
(
SELECT tt2.[Emp],tt2.[Manager],tt2.[Salary]
FROM [YourTable] AS tt1
RIGHT OUTER JOIN [YourTable] AS tt2 ON tt1.[Emp]=tt2.[Manager]
WHERE tt1.[Emp] is NULL
UNION ALL
SELECT r.[Emp],T1.[Manager],r.[Salary]
FROM [YourTable] AS r
INNER JOIN T1 ON r.[Manager]=T1.[Emp]
)
SELECT [Manager],SUM([Salary]) AS Salary
FROM T1
GROUP BY [Manager]
ORDER BY SUM([Salary]) DESC
上記のクエリは、次の質問に対する回答です -
列(従業員、マネージャー、給与)を持つテーブルがあります。1 つの SQL でトップ レベルのマネージャーに対応するすべての従業員の総給与を計算する必要があります。例えば
Input table is :
Emp Manager Salary
A T 10
B A 11
C F 13
D B 5
結果は次のようになります:
Top-Lvl Manager Salary(agg)
T 26
F 13
マネージャーと従業員の階層化は、複数のレベルに進むことができます。