不幸的是,lag由于使用 SQL Server 2008,我無法使用該功能。
我需要在不同時間找到兩個值之間基于機器的差異。
我有一張這樣的桌子:
ID | Time | Value | Machine
------ ----------- --------- -----------
7 | 12:00 | 154400 | 20
6 | 12:00 | 77840 | 17
5 | 11:00 | 10480 | 11
4 | 11:00 | 13214 | 14
3 | 11:00 | 76340 | 17
2 | 11:00 | 15410 | 20
1 | 10:00 | 75000 | 17
我需要找到 id 1 和 3 之間的差異(76340-75000 = 1340)。
之前試過這些:
select
t1.Machine, t1.[ID], t2.[ID], t1.Value, t2.Value,
t2.Value - t1.Value as difference
from
hava t1
cross apply
hava t2
where
t1.Machine = t2.Machine
and t1.ID <> t2.ID
and t1.Machine = 17
但它與 t1.id 與整個表進行比較。
我無法使用lag功能 - 非常感謝您的幫助。
uj5u.com熱心網友回復:
WITH CTE(ID , Time, Value, Machine)AS
(
SELECT 7,'12:00',154400,20 UNION ALL
SELECT 6,'12:00',77840,17 UNION ALL
SELECT 5,'11:00',10480,11 UNION ALL
SELECT 4,'11:00',13214,14 UNION ALL
SELECT 3,'11:00',76340,17 UNION ALL
SELECT 2,'11:00',15410,20 UNION ALL
SELECT 1,'10:00',75000,17
),
CTE2 AS
(
SELECT C.ID,C.TIME,C.Value,C.Machine,
ROW_NUMBER()OVER(PARTITION BY C.MACHINE ORDER BY C.TIME ASC)XCOL
FROM CTE AS C
)
SELECT X.ID,X.Time,X.Value, X2.Value, X.Machine
FROM CTE2 AS X
LEFT JOIN CTE2 AS X2 ON X.Machine=X2.Machine AND X.XCOL=X2.XCOL-1
WHERE X.Machine=17
轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/396693.html
上一篇:根據不同的列計算運行總計摘要
