mysql获取近7天每天数据,无数据补0

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/ljxbbss/article/details/78028424


      接到老大排的活,需要作出一个统计最近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
    SELECT date_sub(curdate(), interval 6 day) as click_date
) a left join (
  select date(FROM_UNIXTIME(getTime/1000,'%Y%m%d')) as datetime, count(*) as count
  from userwechatcard
  group by date(FROM_UNIXTIME(getTime/1000,'%Y%m%d'))
) b on a.click_date = b.datetime;



      其中有个地方需要注意一下:由于我的时间是时间戳类型,而curdate函数返回的是yyyy-MM-dd形式,因此需要在left join的时候将我的时间戳字段getTime进行转换,转换成与curDate函数返回一样的形式,否则就查不到数据;

                                  图2




最终结果:

                                图3



猜你喜欢

转载自blog.csdn.net/ljxbbss/article/details/78028424