-
Notifications
You must be signed in to change notification settings - Fork 30
/
Copy path05- CTEs.sql
38 lines (31 loc) · 853 Bytes
/
05- CTEs.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
--Using a CTE
WITH ProductsByCategory (ProductID, ProductName, Category)
AS
(
SELECT p.ProductID, p.Name, c.Name AS Category
FROM SalesLT.Product AS p
JOIN SalesLT.ProductCategory AS c
ON p.ProductCategoryID = c.ProductCategoryID
)
SELECT Category, COUNT(ProductID) AS Products
FROM ProductsByCategory
GROUP BY Category
ORDER BY Category;
-- Recursive CTE
SELECT * FROM SalesLT.Employee
-- Using the CTE to perform recursion
WITH OrgReport (ManagerID, EmployeeID, EmployeeName, Level)
AS
(
-- Anchor query
SELECT e.ManagerID, e.EmployeeID, EmployeeName, 0
FROM SalesLT.Employee AS e
WHERE ManagerID IS NULL
UNION ALL
-- Recursive query
SELECT e.ManagerID, e.EmployeeID, e.EmployeeName, Level + 1
FROM SalesLT.Employee AS e
INNER JOIN OrgReport AS o ON e.ManagerID = o.EmployeeID
)
SELECT * FROM OrgReport
OPTION (MAXRECURSION 3);