如何使用MySQL计算移动平均线?
我需要做类似的事情:
SELECT value_column1 FROM table1
WHERE datetime_column1 >= '2009-01-01 00:00:00'
ORDER BY datetime_column1;
除了value_column1
,我还需要检索的前20个值的移动平均值value_column1
。
首选标准SQL,但如有必要,我将使用MySQL扩展。
回答:
这只是我的头顶,而且我正要出门,所以未经测试。我也无法想象它会在任何种类的大数据集上表现出色。我确实确认它至少可以正常运行。:)
SELECT value_column1,
(
SELECT
AVG(value_column1) AS moving_average
FROM
Table1 T2
WHERE
(
SELECT
COUNT(*)
FROM
Table1 T3
WHERE
date_column1 BETWEEN T2.date_column1 AND T1.date_column1
) BETWEEN 1 AND 20
)
FROM
Table1 T1
以上是 如何使用MySQL计算移动平均线? 的全部内容, 来源链接: utcz.com/qa/426985.html