Sqlserver
 sql >> Baza danych >  >> RDS >> Sqlserver

Pozyskaj wszystkich pracowników pod zarządem dzięki CTE

możesz spróbować czegoś takiego

;WITH EmployeeTable AS 
(
SELECT 1 EmpId,0 ManagerId ,   5 Level ,'CEO' Value
UNION ALL SELECT 2,1,   4,'EMP'
UNION ALL SELECT 3,1,   4,'ORG'
UNION ALL SELECT 4,2,   3,NULL
UNION ALL SELECT 5,2,   3,NULL
UNION ALL SELECT 6,2,   2,NULL
UNION ALL SELECT 7,1,   1,NULL
UNION ALL SELECT 8,5,   0,NULL
),LevelHire AS
(
        SELECT EmpId, ManagerId,Level,Value
        FROM EmployeeTable
        WHERE EmpId = 2
        UNION ALL
        SELECT RC.EmpId,  RC.ManagerId, Lh.Level,LH.Value
        FROM LevelHire LH
        INNER JOIN [EmployeeTable] RC
        ON LH.EmpId= RC.ManagerId
)
SELECT  E.EmpId, E.ManagerId,E.Level,ISNULL(E.Value ,LH.Value) Value
FROM EmployeeTable E
    LEFT JOIN LevelHire LH
    ON E.EmpId = LH.EmpId


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Wycofanie błędu zgłaszania zagnieżdżonych transakcji w TSQL

  2. Zapytanie o zestaw wyników poprzedniego zapytania

  3. SQL Server — Przeanalizuj wewnętrzne elementy sp_spaceused

  4. SQL Server BIGINT lub DECIMAL (18,0) dla klucza podstawowego

  5. Funkcja niestandardowa z ograniczeniem kontrolnym SQL Server 2008