接到老大排的活,需要作出一个统计最近7天每天的数据做统计用,最终呈现出这样的效果;图1
因为公司库里面所有关于时间都是直接存储时间戳,给我带来了一定的处理上的难度,幸好网上找到一个很好的想法;http://blog.csdn.net/ouyang111222/article/details/77638826
处理方式是:构建一个最近7天的结果集,没有的利用ifnull函数补0操作;
最终的sql如下:
select a.click_date,ifnull(b.count,0) as count
from (
SELECT curdate() as click_date
union all
SELECT date_sub(curdate(), interval 1 day) as click_date
union all
SELECT date_sub(curdate(), interval 2 day) as click_date
union all
SELECT date_sub(curdate(), interval 3 day) as click_date
union all
SELECT date_sub(curdate(), interval 4 day) as click_date
union all
SELECT date_sub(curdate(), interval 5 day) as click_date
union all