mysql 日期取近七天、当前周七天 数据(补全空数据) 简单案例

本文介绍了如何使用MySQL查询近七天和本周的完整日期数据,即使原始数据中存在缺失。通过创建临时日期表并进行关联查询,可以确保查询结果包含七天的所有日期,即使某些日期没有对应的成绩数据。
摘要由CSDN通过智能技术生成

首先我们新建一张测试表格,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
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值