CASE WHEN Color LIKE '%RED%' THEN (10 - (DATEDIFF(MINUTE,Calltime,GETDATE())))
有时可能会给出-10的值。我的问题是当我得到一个值<0,如何将该值更改为过期10分钟。
您可以嵌套CASE语句,但由于现在将文本引入整数值,您必须将所有输出强制转换为字符串:
CASE WHEN Color LIKE '%RED%' THEN
CASE WHEN (10 - (DATEDIFF(MINUTE,Calltime,GETDATE()))) >= 0 THEN CAST((10 - (DATEDIFF(MINUTE,Calltime,GETDATE()))) AS VARCHAR(MAX))
ELSE CAST(ABS((10 - (DATEDIFF(MINUTE,Calltime,GETDATE())))) AS VARCHAR(MAX)) + ' minutes overdue'
END
ELSE -- Additional SQL for when color is not red
END
只需在CASE中使用另一个CASE END。试试这个:
CASE WHEN Color LIKE '%RED%' THEN (CASE WHEN (10 - (DATEDIFF(MINUTE,Calltime,GETDATE()))) < 0 THEN 10 ELSE (10 - (DATEDIFF(MINUTE,Calltime,GETDATE()))) END)
我更喜欢计算lateral join
中的公共值,而不是多次重复我的逻辑。
DECLARE @Test TABLE (CallTime DATETIME, Color VARCHAR(12));
INSERT INTO @Test (Color, CallTime)
SELECT 'RED', DATEADD(MINUTE, -5, GETDATE())
UNION ALL SELECT 'RED', DATEADD(MINUTE, -12, GETDATE())
UNION ALL SELECT 'BLUE', DATEADD(MINUTE, -5, GETDATE());
SELECT
CASE WHEN T.Color LIKE '%RED%' THEN
CASE WHEN C.CallDifference >= 0 THEN CAST(C.CallDifference AS VARCHAR(MAX))
ELSE CAST(ABS(C.CallDifference) AS VARCHAR(MAX)) + ' minutes overdue'
END
ELSE 'BLUE'
END
FROM @Test T
CROSS APPLY (VALUES(10 - (DATEDIFF(MINUTE,T.Calltime,GETDATE())))) as C (CallDifference);
感谢e_i_pi提供的逻辑代码。