mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-18 05:32:52 +00:00
3cc0829cc1
This commit prevents stateful functions like rowNumberInAllBlocks from being modified in getHeader() calls.
38 lines
975 B
SQL
38 lines
975 B
SQL
-- https://stackoverflow.com/questions/53416531/clickhouse-moving-average
|
|
|
|
DROP TABLE IF EXISTS test.bm;
|
|
|
|
USE test;
|
|
|
|
CREATE TABLE bm (amount float, business_dttm DateTime) engine Log;
|
|
|
|
INSERT INTO bm VALUES (0.3,'2018-11-19 13:00:00'), (0.3,'2018-11-19 13:05:00'), (0.4,'2018-11-19 13:10:00'), (0.5,'2018-11-19 13:15:00'), (0.6,'2018-11-19 13:15:00'), (0.7,'2018-11-19 13:20:00'), (0.8,'2018-11-19 13:25:00'), (0.9,'2018-11-19 13:25:00'), (0.5,'2018-11-19 13:30:00');
|
|
|
|
WITH
|
|
(
|
|
SELECT arrayCumSum(groupArray(amount))
|
|
FROM
|
|
(
|
|
SELECT
|
|
amount
|
|
FROM bm
|
|
ORDER BY business_dttm
|
|
)
|
|
) AS arr,
|
|
1 + rowNumberInAllBlocks() AS id,
|
|
3 AS window_size
|
|
SELECT
|
|
amount,
|
|
business_dttm,
|
|
if(id < window_size, NULL, round(arr[id] - arr[id - window_size], 4)) AS moving_sum
|
|
FROM
|
|
(
|
|
SELECT
|
|
amount,
|
|
business_dttm
|
|
FROM bm
|
|
ORDER BY business_dttm
|
|
);
|
|
|
|
DROP TABLE test.bm;
|