例如,这将返回 55 的 ORDER NUMBER 和 55 的 Calc_ORDER_NUMBER_LAG,Calc_Qty_Changed 列没有给我 2,即使它们相等......
USE MfgMetrics
SELECT
[ORDER NUMBER],
[Calc_ORDER_NUMBER_LAG] = LAG([ORDER NUMBER],1,0)
OVER (Order By [ORDER NUMBER],[FileDate]),
--Order Number and File Date
[Order_Quantity],
[Calc_Order_Quantity_LAG] = LAG([Order_Quantity],1,0)
OVER (Order By [ORDER NUMBER], [FileDate]),
[Calc_Qty_Changed] =
(CASE
WHEN [ORDER NUMBER] = [Calc_ORDER_NUMBER_LAG] THEN 2
WHEN [ORDER NUMBER] != [Calc_ORDER_NUMBER_LAG] AND
[Order_Quantity] != [Calc_Order_Quantity_LAG] AND
[ACTUAL START DATE] != 0 AND
[FileDate] >= [ACTUAL START DATE] THEN 1
ELSE 0
END)
FROM
dbo.Table_II
为什么每次都跳到 ELSE 0,即使满足其他 CASE WHEN 条件?