Hierarchical and Recursive Queries in SQL Server
Jasmin Ludolf
Content Developer
The organization is described by:
ID
- Employee IDName
of EmployeeJobTitle
in the companyDepartment
in the companySupervisor
in the companyFields describing hierarchy:
ID
Supervisor
Employee 2 has Supervisor 1
+-----------------------+---------------------+------------+------------+
|ID | Name | Position | Department | Supervisor |
|-----------------------|---------------------|------------|------------|
| 1 | Heinz Griesser | IT Director | IT | 0 |
| 2 | Andreas Sitter | Security Manager | IT | 1 |
| 3 | Thomas Bergman | Innovation Manager | IT | 1 |
| 4 | Hannes Berg | Operation Manager | IT | 1 |
| 5 | Anna Kruggel | Administrator | IT | 4 |
| 6 | Karin Pacher | Developer | IT | 4 |
+-----------------------+---------------------+------------+------------+
Get the hierarchy of a record
Who is your supervisor?
Get the level of the hierarchy
Get the hierarchy level of an organization
Combine recursion results into one field
Which supervisors do I have?
WITH hierarchy AS ( SELECT ID,Supervisor FROM employee WHERE supervisor = 0
UNION ALL SELECT emp.ID, emp.Supervisor FROM employee emp
JOIN hierarchy ON emp.Supervisor = hierarchy.ID) SELECT * FROM hierarchy
+---+-----------+
|ID |Supervisor |
|---|-----------|
|1 | 0 |
|2 | 1 |
|3 | 2 |
+---+-----------+
WITH hierarchy AS ( SELECT ID, Supervisor, 1 as LEVEL FROM employee WHERE Supervisor = 0
UNION ALL SELECT emp.ID, emp.Supervisor, LEVEL + 1 FROM employee emp
JOIN hierarchy ON emp.Supervisor = hierarchy.ID ) SELECT * FROM hierarchy
+---+-----------+-------|
|ID |Supervisor | Level |
|---|-----------|-------|
|1 | 0 | 0 |
|2 | 1 | 1 |
+---+-----------+-------+
WITH hierarchy AS ( SELECT ID, Supervisor, CAST('0' AS VARCHAR(MAX)) as PATH FROM employee WHERE Supervisor = 0
UNION ALL SELECT emp.ID, emp.Supervisor, Path + '->' + CAST(emp.Supervisor AS VARCHAR(MAX)) FROM employee emp INNER JOIN hierarchy ON emp.Supervisor = hierarchy.ID ) SELECT * FROM hierarchy
+-----+--------+
| PATH |
|--------------|
| 0 -> 1 -> 4 |
+-----+--------+
Hierarchical and Recursive Queries in SQL Server