例として、これは 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
他の CASE WHEN 条件が満たされている場合でも、毎回 ELSE 0 にスキップするのはなぜですか?