Hiërarchische en recursieve queries in SQL Server
Jasmin Ludolf
Content Developer
De organisatie wordt beschreven door:
ID - Medewerker-IDName van medewerkerJobTitle in het bedrijfDepartment in het bedrijfSupervisor in het bedrijfVelden die de hiërarchie beschrijven:
IDSupervisorMedewerker 2 heeft 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 |
+-----------------------+---------------------+------------+------------+
De hiërarchie van een record ophalen
Wie is je supervisor?
Het hiërarchieniveau ophalen
Bepaal het hiërarchieniveau van een organisatie
Recursieresultaten samenvoegen in één veld
Welke supervisors heb ik?
WITH hierarchy AS ( SELECT ID,Supervisor FROM employee WHERE supervisor = 0UNION ALL SELECT emp.ID, emp.Supervisor FROM employee empJOIN 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 = 0UNION ALL SELECT emp.ID, emp.Supervisor, LEVEL + 1 FROM employee empJOIN 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 = 0UNION 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 |
+-----+--------+
Hiërarchische en recursieve queries in SQL Server