У меня есть таблица пользователей
data:image/s3,"s3://crabby-images/22aac/22aac2df44999ed4930415c6371b082dd7a3d1ed" alt="enter image description here"
, и я хочу найти для каждого пользователя своего первого менеджера по иерархии его рабочих мест.
Мне удалось написать этот скрипт, но я не могу заставить его работать должным образом. Мне нужно, чтобы у пользователя 1003 был 1001 managerId. Теперь он показывает 1002.
data:image/s3,"s3://crabby-images/920f6/920f6e24b71636972ae2e2ae2e645179cd8de120" alt="enter image description here"
select 1001 as userid, 'L1' as locationCode, NULL as parentLocationCode, 1 as isManager into #Users union all
select 1002 as userid, 'L2' as locationCode, 'L1' as parentPad, 0 as isManager union all
select 1003 as userid, 'L3' as locationCode, 'L2' as parentPad, 0 as isManager
;WITH cte_org AS (
SELECT
d.userid
,d.locationCode
,d.parentLocationCode
,d.isManager
,null as managerId
FROM
#Users as d
WHERE d.parentLocationCode is NULL
UNION ALL
SELECT
d.userid
,d.locationCode
,d.parentLocationCode
,d.isManager
,o.userid as managerId
FROM
#Users as d
inner JOIN cte_org o on d.parentLocationCode=o.locationCode
)
SELECT *
FROM cte_org
OPTION (MAXRECURSION 32767);