dbo.uspGetManagerEmployees Stored Procedure
In This Topic
Description
Stored procedure using a recursive query to return the direct and indirect employees of the specified manager.
Properties
Creation Date | 27/10/2017 14:33 |
Encrypted | data:image/s3,"s3://crabby-images/40c29/40c29bac2ae821a2b54c4a97ae80bccb0d706883" alt="" |
Ansi Nulls | data:image/s3,"s3://crabby-images/8bc22/8bc229d4ed9c6401e856def37cea36edd36be4b1" alt="" |
Parameters
Parameter | Direction | Description | Data Type | Size |
@BusinessEntityID | In | Input parameter for the stored procedure uspGetManagerEmployees. Enter a valid BusinessEntityID of the manager from the HumanResources.Employee table. | Integer | 4 |
@RETURN_VALUE | Return Value | | Integer | 4 |
Objects that dbo.uspGetManagerEmployees depends on
| Database Object | Object Type | Description | Dep Level |
data:image/s3,"s3://crabby-images/b385b/b385b0bac8426945f16ffa45c7ced06b478bf9cf" alt="Person.BusinessEntity table" | Person.BusinessEntity | Table | Source of the ID that connects vendors, customers, and employees with address and contact information. | 2 |
data:image/s3,"s3://crabby-images/b385b/b385b0bac8426945f16ffa45c7ced06b478bf9cf" alt="HumanResources.Employee table" | HumanResources.Employee | Table | Employee information such as salary, department, and title. | 3 |
data:image/s3,"s3://crabby-images/ecbbb/ecbbb4d04efd2715d15ad3717224d8e5502422f5" alt="dbo.Flag datatype" | dbo.Flag | User Defined Data Type | | 4 |
data:image/s3,"s3://crabby-images/ecbbb/ecbbb4d04efd2715d15ad3717224d8e5502422f5" alt="dbo.Name datatype" | dbo.Name | User Defined Data Type | | 2 |
data:image/s3,"s3://crabby-images/ecbbb/ecbbb4d04efd2715d15ad3717224d8e5502422f5" alt="dbo.NameStyle datatype" | dbo.NameStyle | User Defined Data Type | | 5 |
data:image/s3,"s3://crabby-images/b385b/b385b0bac8426945f16ffa45c7ced06b478bf9cf" alt="Person.Person table" | Person.Person | Table | Human beings involved with AdventureWorks: employees, customer contacts, and vendor contacts. | 4 |
Procedure Source Code
CREATE PROCEDURE [dbo].[uspGetManagerEmployees]
@BusinessEntityID [int]
AS
BEGIN
SET NOCOUNT ON;
-- Use recursive query to list out all Employees required for a particular Manager
WITH [EMP_cte]([BusinessEntityID], [OrganizationNode], [FirstName], [LastName], [RecursionLevel]) -- CTE name and columns
AS (
SELECT e.[BusinessEntityID], e.[OrganizationNode], p.[FirstName], p.[LastName], 0 -- Get the initial list of Employees for Manager n
FROM [HumanResources].[Employee] e
INNER JOIN [Person].[Person] p
ON p.[BusinessEntityID] = e.[BusinessEntityID]
WHERE e.[BusinessEntityID] = @BusinessEntityID
UNION ALL
SELECT e.[BusinessEntityID], e.[OrganizationNode], p.[FirstName], p.[LastName], [RecursionLevel] + 1 -- Join recursive member to anchor
FROM [HumanResources].[Employee] e
INNER JOIN [EMP_cte]
ON e.[OrganizationNode].GetAncestor(1) = [EMP_cte].[OrganizationNode]
INNER JOIN [Person].[Person] p
ON p.[BusinessEntityID] = e.[BusinessEntityID]
)
-- Join back to Employee to return the manager name
SELECT [EMP_cte].[RecursionLevel], [EMP_cte].[OrganizationNode].ToString() as [OrganizationNode], p.[FirstName] AS 'ManagerFirstName', p.[LastName] AS 'ManagerLastName',
[EMP_cte].[BusinessEntityID], [EMP_cte].[FirstName], [EMP_cte].[LastName] -- Outer select from the CTE
FROM [EMP_cte]
INNER JOIN [HumanResources].[Employee] e
ON [EMP_cte].[OrganizationNode].GetAncestor(1) = e.[OrganizationNode]
INNER JOIN [Person].[Person] p
ON p.[BusinessEntityID] = e.[BusinessEntityID]
ORDER BY [RecursionLevel], [EMP_cte].[OrganizationNode].ToString()
OPTION (MAXRECURSION 25)
END;
|
See Also