2016-07-15 177 views
0

我有一个包含nazwa,wartosc,czas的进程数据的表。该表的数据看起来像this计算两个记录之间差异(时间)的总和 - mssql

现在我写查询:

;WITH [cteRows] AS 
(
    SELECT [nazwa], 
      [wartosc], 
      [czas], 
      ROW_NUMBER() OVER (ORDER BY [czas]) AS [RowNumber] 
    FROM [test].[dbo].[coldbox7] 
    WHERE [nazwa] = 'coldbox7/WymianaDanychDB/Hydraulic' 
    AND [czas] >= '2016-07-14 22:00:00.000' 
    AND [czas] <= '2016-07-14 22:30:00.000' 
) 
SELECT mc.[RowNumber], 
     mc.[czas], 
     mc.[nazwa], 
     mc.[wartosc], 
     DATEDIFF(SECOND, mc.[czas], ISNULL(mp.[czas], mc.[czas])) AS [Wsekundach] 
FROM [cteRows] mc 
LEFT JOIN [cteRows] mp 
    ON mc.[RowNumber] = mp.[RowNumber] + 1 
WHERE mc.[wartosc] = 0 

和输出look like:

我有一个问题: 我怎样才能使[Wsekundach],而不是本次输出一行总和?

+0

由于其他列在所有行中都有不同的数据:如果结果减少为单行,您希望在那里显示哪些信息? – Shnugo

+0

我会有关于所有时差的信息。 [Wsekundach] –

+0

这不仅仅是第一行和最后一行之间的区别吗? –

回答

0

尝试以下操作:

;WITH [cteRows] AS 
(
    SELECT [nazwa], 
      [wartosc], 
      [czas], 
      ROW_NUMBER() OVER (ORDER BY [czas]) AS [RowNumber] 
    FROM [test].[dbo].[coldbox7] 
    WHERE [nazwa] = 'coldbox7/WymianaDanychDB/Hydraulic' 
    AND [czas] >= '2016-07-14 22:00:00.000' 
    AND [czas] <= '2016-07-14 22:30:00.000' 
) 

, cteNewRows AS 
(
    SELECT mc.[RowNumber], 
      mc.[czas], 
      mc.[nazwa], 
      mc.[wartosc], 
      DATEDIFF(SECOND, mc.[czas], ISNULL(mp.[czas], mc.[czas])) AS [Wsekundach] 
    FROM [cteRows] mc 
    LEFT JOIN [cteRows] mp ON mc.[RowNumber] = mp.[RowNumber] + 1 
    WHERE mc.[wartosc] = 0 
) 

SELECT SUM(Wsekundach) AS SumOfWsekundach 
FROM cteNewRows 
+0

我有一行错误: ; WITH cteNewRows AS ';'附近语法不正确。 –

+0

@ G.Dabrowski,查询编辑。 –

+0

非常感谢,你能告诉我我怎样才能做到,当最后一行有wartosc = 1而不是添加到[Wsekundach] 7.行的日期时间和'2016-07-14 22:30: 00.000' –

0

如果你想一排就是区别,我想你可以使用一个更简单的查询:

 SELECT DATEDIFF(SECOND, MIN(c.[czas]), MAX(c.[czas]) 
     FROM [test].[dbo].[coldbox7] c 
     WHERE [nazwa] = 'coldbox7/WymianaDanychDB/Hydraulic' AND 
      [czas] >= '2016-07-14 22:00:00.000' AND 
      [czas] <= '2016-07-14 22:30:00.000' AND 
      c.[wartosc] = 0; 

这样做只是基于最大之和最小值是比总结中间和更高效。

相关问题