mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-18 20:32:43 +00:00
47 lines
3.2 KiB
Markdown
47 lines
3.2 KiB
Markdown
---
|
|
slug: /ru/sql-reference/aggregate-functions/reference/deltasumtimestamp
|
|
sidebar_position: 141
|
|
---
|
|
|
|
# deltaSumTimestamp {#agg_functions-deltasumtimestamp}
|
|
|
|
Суммирует разницу между последовательными строками. Если разница отрицательна — она будет проигнорирована.
|
|
|
|
Эта функция предназначена в первую очередь для [материализованных представлений](../../../sql-reference/statements/create/view.md#materialized), хранящих данные, упорядоченные по некоторому округленному временному интервалу, согласно timestamp, например, по бакету `toStartOfMinute`. Поскольку строки в таком материализованном представлении будут иметь одинаковый timestamp, их невозможно объединить в правильном порядке без хранения исходного, неокругленного значения timestamp. Функция `deltaSumTimestamp` отслеживает исходные `timestamp` наблюдаемых значений, поэтому значения (состояния) функции правильно вычисляются во время слияния кусков.
|
|
|
|
Чтобы вычислить разницу между упорядоченными последовательными строками, вы можете использовать функцию [deltaSum](../../../sql-reference/aggregate-functions/reference/deltasum.md#agg_functions-deltasum) вместо функции `deltaSumTimestamp`.
|
|
|
|
**Синтаксис**
|
|
|
|
``` sql
|
|
deltaSumTimestamp(value, timestamp)
|
|
```
|
|
|
|
**Аргументы**
|
|
|
|
- `value` — входные значения, должны быть типа [Integer](../../data-types/int-uint.md), или [Float](../../data-types/float.md), или [Date](../../data-types/date.md), или [DateTime](../../data-types/datetime.md).
|
|
- `timestamp` — параметр для упорядочивания значений, должен быть типа [Integer](../../data-types/int-uint.md), или [Float](../../data-types/float.md), или [Date](../../data-types/date.md), или [DateTime](../../data-types/datetime.md).
|
|
|
|
**Возвращаемое значение**
|
|
|
|
- Накопленная разница между последовательными значениями, упорядоченными по параметру `timestamp`.
|
|
|
|
Тип: [Integer](../../data-types/int-uint.md), или [Float](../../data-types/float.md), или [Date](../../data-types/date.md), или [DateTime](../../data-types/datetime.md).
|
|
|
|
**Пример**
|
|
|
|
Запрос:
|
|
|
|
```sql
|
|
SELECT deltaSumTimestamp(value, timestamp)
|
|
FROM (SELECT number AS timestamp, [0, 4, 8, 3, 0, 0, 0, 1, 3, 5][number] AS value FROM numbers(1, 10));
|
|
```
|
|
|
|
Результат:
|
|
|
|
``` text
|
|
┌─deltaSumTimestamp(value, timestamp)─┐
|
|
│ 13 │
|
|
└─────────────────────────────────────┘
|
|
```
|