Я пытаюсь получить отчет о времени, потраченном на работу над билетом. В основном, у меня есть несколько сотрудников, работающих над одним билетом, и я хочу сообщить, сколько времени они проработали над билетом.
Например:
Сотрудник А работал над билет с 12 до 17 часов, и во время этого билета он находился в режиме ожидания в течение часа, т.е. с 15 до 16 часов, что необходимо исключить из общего времени, потраченного сотрудником А на билет.
Расчет:
Разница во времени в часах: 5
Билет в состоянии ожидания в часах: 1
Конечное время в часах: 4
Мне нужна ваша помощь в том, как это можно сделать SQL.
Вот что у меня есть:
DROP TABLE IF EXISTS #INC_Data;
CREATE TABLE #INC_Data (
IncidentNumber NVARCHAR(20) NOT NULL
,Mi_Definition VARCHAR(255) NOT NULL
,Mi_Value VARCHAR(255)
,Mi_Start DATETIME
,Mi_End DATETIME
)
INSERT INTO #INC_Data (
IncidentNumber
,Mi_Definition
,Mi_Value
,Mi_Start
,Mi_End
)
VALUES (
'INC8574030'
,'Create to Resolve Duration'
,NULL
,'10/30/2019 7:26:20 PM'
,'10/30/2019 7:56:40 PM'
)
,(
'INC8574030'
,'Incident State Duration'
,'Active'
,'10/30/2019 7:26:22 PM'
,'10/30/2019 7:28:21 PM'
)
,(
'INC8574030'
,'Assignment Group'
,'Unix-Lev-L1-team2'
,'10/30/2019 7:26:22 PM'
,'11/8/2019 8:00:28 PM '
)
,(
'INC8574030'
,'Incident State Duration'
,'In Progress'
,'10/30/2019 7:28:21 PM'
,'10/30/2019 7:56:30 PM'
)
,(
'INC8574030'
,'Assigned to Duration'
,'Ayush Chauhan'
,'10/30/2019 7:28:21 PM'
,'11/8/2019 8:00:28 PM '
)
,(
'INC8574030'
,'Incident State Duration'
,'Pending'
,'10/30/2019 7:56:28 PM'
,'10/30/2019 7:56:40 PM'
)
,(
'INC8574030'
,'Incident State Duration'
,'Resolved'
,'10/30/2019 7:56:40 PM'
,'11/8/2019 8:00:28 PM '
)
,(
'INC8574030'
,'Incident State Duration'
,'Closed'
,'11/8/2019 8:00:28 PM'
,NULL
)
,(
'INC8909432'
,'Create to Resolve Duration'
,NULL
,'12/23/2019 7:31:14 PM'
,'12/24/2019 12:59:29 PM'
)
,(
'INC8909432'
,'Incident State Duration'
,'Active'
,'12/23/2019 7:31:18 PM'
,'12/23/2019 7:42:59 PM'
)
,(
'INC8909432'
,'Assignment Group'
,'TDS-IS Data Compliance'
,'12/23/2019 7:31:18 PM'
,'1/2/2020 2:00:18 PM'
)
,(
'INC8909432'
,'Incident State Duration'
,'In Progress'
,'12/23/2019 7:42:59 PM'
,'12/23/2019 7:57:33 PM'
)
,(
'INC8909432'
,'Assigned to Duration'
,'Deepika N'
,'12/23/2019 7:42:59 PM'
,'12/23/2019 7:57:33 PM'
)
,(
'INC8909432'
,'Incident State Duration'
,'Pending'
,'12/23/2019 7:57:33 PM'
,'12/24/2019 12:59:29 PM'
)
,(
'INC8909432'
,'Assigned to Duration'
,'Gowtham Komisettu'
,'12/23/2019 7:57:33 PM'
,'12/24/2019 12:18:44 PM'
)
,(
'INC8909432'
,'Assigned to Duration'
,'Abhinav P'
,'12/24/2019 12:18:44 PM'
,'1/2/2020 2:00:18 PM'
)
,(
'INC8909432'
,'Incident State Duration'
,'Resolved'
,'12/24/2019 12:59:29 PM'
,'1/2/2020 2:00:18 PM'
)
,(
'INC8909432'
,'Incident State Duration'
,'Closed'
,'1/2/2020 2:00:18 PM'
,NULL
)
--SELECT * FROM #INC_Data
--Order by IncidentNumber, Mi_Start
Запрос для подсчета часов, потраченных на правопреемника на билете и исключить ожидающие часы под ним
;WITH CTE
AS (
SELECT d.IncidentNumber
,d.Mi_Definition
,d.Mi_Value
,d.Mi_Start
,d.Mi_End
,DATEDIFF(MINUTE, d.Mi_Start, d.Mi_End) AS Duration_in_Minutes
FROM #INC_Data d
WHERE (
d.Mi_Definition = 'Assigned to Duration'
OR d.Mi_Value = 'Pending'
)
)
,Total
AS (
SELECT C.IncidentNumber
,C.Mi_Value AS [Assigned / Pending]
,SUM(C.Duration_in_Minutes) AS [Total (Min)]
FROM CTE C
GROUP BY C.IncidentNumber
,C.Mi_Value
)
SELECT T.IncidentNumber
,T.[Assigned / Pending]
,T.[Total (Min)]
,CASE
WHEN T.[Total (Min)] < 0
AND T.[Total (Min)] > - 60
THEN '-'
ELSE TRY_CAST(T.[Total (Min)] / 60 AS VARCHAR) + ':' + right('0' + CAST(ABS(T.[Total (Min)]) % 60 AS VARCHAR(2)), 2)
END [Total (HH:mm:ss)]
FROM Total T
ORDER BY T.IncidentNumber
,T.[Assigned / Pending]