SQL Запрос для расчета показаний потребления, перечисленных с 30-минутными интервалами, необходимо упорядочить по дате, времени и серийному номеру счетчика DESC - PullRequest
0 голосов
/ 10 июля 2020

Привет, участники переполнения стека :)

Мне нужно получить потребление для каждой строки при активном чтении. Внесите разницу в столбец расхода. Разница за каждые 30 минут. например; 17897352 - 17897335 = 17 as [потребление / 30 мин] Но я не хочу группировать его по дате, но его нужно упорядочить по дате, времени и метке DES C.

Пример содержимого таблицы:

DeviceReadingID MeterRefID  DateTimeStamp   ForwardActiveReading  
284729948   ELON102582  2020-07-01 00:00:00.000 17897352
284756341   ELON102582  2020-06-30 23:30:00.000 17897335
284746613   ELON102582  2020-06-30 23:00:00.000 17897319
284710326   ELON102582  2020-06-30 22:30:00.000 17897303
284743959   ELON102582  2020-06-30 22:00:00.000 17897286
284762422   ELON102582  2020-06-30 21:30:00.000 17897270
284739309   ELON102582  2020-06-30 21:00:00.000 17897253
284758349   ELON102582  2020-06-30 20:30:00.000 17897237
284675646   ELON102582  2020-06-30 20:00:00.000 17897220
284686333   ELON102582  2020-06-30 19:30:00.000 17897204
284559642   ELON102582  2020-06-30 19:00:00.000 17897187
284560601   ELON102582  2020-06-30 18:30:00.000 17897171
284659743   ELON102582  2020-06-30 18:00:00.000 17897154
284657476   ELON102582  2020-06-30 17:30:00.000 17897111
284655871   ELON102582  2020-06-30 17:00:00.000 17897055
284636705   ELON102582  2020-06-30 16:30:00.000 17896998
284653158   ELON102582  2020-06-30 16:00:00.000 17896941
284624220   ELON102582  2020-06-30 15:30:00.000 17896885
284619064   ELON102582  2020-06-30 15:00:00.000 17896828

Спасибо, я был бы очень признателен за помощь с указанным выше. Кажется, я не могу понять, как это сделать

Я пытался использовать приведенный ниже пример, но это не помогло

        WITH    SampleData  AS
    (
            SELECT  [TimeStamp], [MeterID], [Count]
            FROM    (   VALUES
                        ('2013-09-28 00:00:10', 'BA123', 1453.034),
                        ('2013-09-28 00:01:12', 'BA123', 1454.770),
                        ('2013-09-28 00:00:14', 'BB777', 2351.000),
                        ('2013-09-28 23:59:50', 'BA123', 1470.120),
                        ('2013-09-29 00:00:05', 'BA123', 1470.445)
                    )   AS SampleData([TimeStamp], [MeterID], [Count])
    )
    
    
    
    SELECT      MeterId, CAST([TimeStamp] AS datetime) AS [DateConsumption],
                MAX([Count]) - MIN([Count]) AS [CountConsumption]
    FROM        SampleData
    GROUP BY    MeterID, CAST([TimeStamp] AS datetime)
    --WITH ROLLUP

Я хочу выполнить Select Query, который даст мне следующий результат:

ОЖИДАЕМЫЙ РЕЗУЛЬТАТ

1 Ответ

0 голосов
/ 10 июля 2020

Этот запрос добавляет столбец «Потребление» к выходным данным таблицы примеров

select *, ForwardActiveReading - lead(ForwardActiveReading, 1, 0) over(order by DateTimeStamp desc)
from yourtable
order by DateTimeStamp desc
...