按天统计数据,如果当天没有记录,则统计为0

    今天做一个统计需求,按天统计这张表的记录数,按照pay_month和格式化之后的payment_time来分组,这张表大致数据如下


    按照pay_month和格式化之后的payment_time分组之后,数据如下




    我需要统计的是10天前到今天的数据,但就pay_month=1的数据来讲,只有2,3,4,7号有数据。而我想要没有数据的那一天同样统计出来并用0来填充。
     第一反应是用left join,但由于mysql没有oracle的connect by level,只能用一张数据条数绝对大于10的表来代替select level from dual connect by level < 10;我就选了tb_order这张表本身
SELECT @cdate := date_add(@cdate,interval -1 day) days from 
(SELECT @cdate := CURDATE() from tb_order limit 10) t1

   

    再left join需要分组的表
select t2.days,t3.begin_day,t3.end_day,t3.pay_month,
			 t3.pay_day,IFNULL(t3.score,0) total_score from 
	(SELECT @cdate := date_add(@cdate,interval -1 day) days from 
		(SELECT @cdate := CURDATE() from tb_order limit 10) t1) t2
LEFT JOIN
	(select CURDATE() end_day,PAY_MONTH,
	 date_add(CURDATE(),interval -10 day) begin_day,
	 date_format(PAYMENT_TIME,'%Y-%m-%d') pay_day,
	 count(1) score from tb_order
	where ORDER_STATUS='ORDER_USED' 
	and CURDATE()<=date_add(date_format(PAYMENT_TIME,'%Y-%m-%d'),interval 10 day)
	group by PAY_MONTH,date_format(PAYMENT_TIME,'%Y-%m-%d')) t3
on t2.days=t3.pay_day

    最终达到的结果如下:



    正真需要的只有days和total_score两列,这样就算是完成了。
  • 大小: 25.5 KB
  • 大小: 25 KB
  • 大小: 14.4 KB
  • 大小: 16.7 KB
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值