如何使用 MySQL 计算移动平均线?
问题:如何使用 MySQL 计算移动平均线? 我需要做类似的事情: SELECT value_column1 FROM table1 WHERE datetime_column1 >= '2009-01-01 00:00:00' ORDER BY datetime_column1; 除了value_column1之外,我还需要取value_column1的前20个值的移动平均线。 首选标准 SQL
·
问题:如何使用 MySQL 计算移动平均线?
我需要做类似的事情:
SELECT value_column1
FROM table1
WHERE datetime_column1 >= '2009-01-01 00:00:00'
ORDER BY datetime_column1;
除了value_column1
之外,我还需要取value_column1
的前20个值的移动平均线。
首选标准 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
更多推荐
已为社区贡献23584条内容
所有评论(0)