Mysql
 sql >> Base de données >  >> RDS >> Mysql

Calculer une moyenne mobile MySQL ?

Si vous voulez la moyenne mobile pour chaque date, essayez ceci :

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

Il utilise une sous-requête corrélée pour calculer la moyenne de 9 valeurs.