Nếu dòng thời gian của bạn liên tục (1 giá trị mỗi ngày), bạn có thể cải thiện lần thử đầu tiên của mình như sau:
SELECT c.date,
( SELECT AVERAGE(m.value)
FROM measures as m
WHERE m.measured_on_dt
BETWEEN DATE_SUB(c.date, INTERVAL 5 day) AND c.date
) as `average_to_date`
FROM calendar c
WHERE c.date between date1 AND date2 -- graph boundaries
ORDER BY c.date ASC
Nếu dòng thời gian của bạn có lỗ hổng, điều này sẽ dẫn đến ít hơn 5 giá trị cho mức trung bình.