Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Berechnung eines gleitenden Durchschnitts MySQL?

Wenn Sie den gleitenden Durchschnitt für jedes Datum haben möchten, versuchen Sie Folgendes:

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

Es verwendet eine korrelierte Unterabfrage, um den Durchschnitt von 9 Werten zu berechnen.