SQL Server'da Hiyerarşik ve Özyinelemeli Sorgular
Jasmin Ludolf
Content Developer
Kuruluş şu şekilde tanımlanır:
ID - Çalışan kimliğiName alanıJobTitleDepartmentSupervisorHiyerarşiyi tanımlayan alanlar:
IDSupervisorÇalışan 2'nin yöneticisi 1'dir
+-----------------------+---------------------+------------+------------+
|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 |
+-----------------------+---------------------+------------+------------+
Bir kaydın hiyerarşisini alın
Yöneticiniz kim?
Hiyerarşi düzeyini alın
Bir kuruluşun hiyerarşi düzeyini alın
Özyineleme sonuçlarını tek alanda birleştirin
Hangi yöneticilere sahibim?
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 |
+-----+--------+
SQL Server'da Hiyerarşik ve Özyinelemeli Sorgular