首先我们新建一张测试表格,date_day为日期,score为成绩,表格名ceshi。
我们如果取近七天的每天总成绩数据,常用的sql应该是:
SELECT date_day,sum(score) as score FROM ceshi WHERE DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= date(date_day) GROUP BY date_day ORDER BY date_day
执行结果为:
这样虽然得出了结果,但是如果数据库里没有完整的7天数据,那么他只能得到已有的三天数据。
所以我们需要改一下sql,关联一张自己创建的7天日期临时表:
select d.date, IFNULL(T.score,0) socre from
(
SELECT CURDATE() AS date
UNION ALL
SELECT DATE_SUB(CURDATE(), INTERVAL 1 DAY) AS date
UNION ALL
SELECT DATE_SUB(CURDATE(), INTERVAL 2 DAY) AS date
U