希望我能正确解释这一点
我正在尝试计算滚动平均值,但前面的行数可变,具体取决于另一列的滚动总和。或者换句话说,我想计算 b 列的最近平均值,在之前的行中,a 列的总和至少为 X
示例数据:
CREATE TEMP TABLE t (ts timestamp NOT NULL, a int, b int);
INSERT INTO t VALUES
('20200929 11:00',1,50)
,('20200929 12:00',3,25)
,('20200929 13:00',1,20)
,('20200929 14:00',1,19)
,('20200929 15:00',2,25)
,('20200929 16:00',1,22)
,('20200929 17:00',3,19)
期望的结果,X = 3:
ts a b row_from row_to average_b
2020-09-29 11:00 1 50 NULL NULL NULL
2020-09-29 12:00 3 25 1 1 50
2020-09-29 13:00 1 20 2 2 25
2020-09-29 14:00 1 19 2 3 22.5
2020-09-29 15:00 2 25 2 4 21.333
2020-09-29 16:00 1 22 4 5 22.5
2020-09-29 17:00 3 19 5 6 23.5
我没有计算当前行的 a 值,因此 row_to 始终是前一行。
第三行只需要第2行
第四行需要第 2 行和第 3 行,因为第 2 行本身不是 >=3。我不介意超过 X 值。
我可以对可变数量的行进行平均,但我不知道如何计算所需的 row_from。我想这在 python 中很容易,但是在 TSQL 中是否有基于集合的方法来做到这一点?
我正在使用 PostgreSQL 10.5,但也可以使用 SQLServer 2019