Найдите вершину Иерархии - PullRequest
1 голос
/ 06 июня 2019

У меня есть следующая таблица: сотрудники

employee   emp_id manager  manager_id
a          1      x        1
b          2      a        1
c          3      b        2

Я пытаюсь показать, что x 1 является топ-менеджером для a, b и c, даже если a 1 является менеджером b 2, а b 2 является c3-х менеджер.Вот что я пытаюсь сделать:

employee employee_id top_manager top_manager_id
a        1           x           1 
b        2           x           1
c        3           x           1

Код, который я пробовал

 WITH 
    report AS 
    (
     SELECT employee, employee_id, top_manager, top_manager_id
       FROM employees
      UNION ALL
     SELECT e.employee, e.employee_id, e.top_manager, e.top_manager_id
       FROM dbo.employees e
      INNER JOIN report r ON e.employee_id = r.top_manager_id 
    )
     SELECT employee, employee_id, top_manager, top_manager_id
       FROM report

1 Ответ

0 голосов
/ 06 июня 2019

Использование рекурсивного CTE :

;WITH all_managers_per_employee (employee_id, manager, manager_id)
AS
(
   select employee_id, manager, manager_id from employees -- Anchor member
   UNION ALL
   select all_managers_per_employee.employee_id, line_manager.manager, line_manager.manager_id -- Recursive member; references cte table, all_managers_per_employee .
   from all_managers_per_employee 
     join employees line_manager on line_manager.employee = all_managers_per_employee.manager
   where line_manager.manager <> line_manager.employee
),
tops (employee)
AS
(
    select distinct manager as employee
    from employees
    where manager not in (select employee from employees where manager<>employee)
)
select employees.employee, employees.employee_id, tops.employee as top_manager, all_managers_per_employee.manager_id as top_manager_id 
from all_managers_per_employee
    join tops on tops.employee = all_managers_per_employee.manager
    join employees on employees.employee_id = all_managers_per_employee.employee_id
order by 3,1;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...