Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

Calculando uma média móvel MySQL?


Se você quiser a média móvel para cada data, tente isto:
SELECT date, SUM(close),
       (select avg(close) from tbl t2 where t2.name_id = t.name_id and datediff(t2.date, t.date) <= 9
       ) as mvgAvg
FROM tbl t
WHERE date <= '2002-07-05' and
      name_id = 2
GROUP BY date
ORDER BY date DESC

Ele usa uma subconsulta correlacionada para calcular a média de 9 valores.