问题:如何使用 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
Logo

华为、百度、京东云现已入驻,来创建你的专属开发者社区吧!

更多推荐