欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

mysql groupBy 按日期分组

程序员文章站 2022-03-22 15:36:59
需求中经常会有按日期,月份,年份分组统计的操作那么groupBy直接是实现不了的,需要转化一下,话不多说,看代码SELECTFROM_UNIXTIME(create_time, '%Y-%m-%d') as day, create_time,count( DISTINCT uid ) AS amount FROM`black_production_user` WHEREcreate_time >= 1588262400 AND create_time <= 16...

需求中经常会有按日期,月份,年份分组统计的操作

那么groupBy直接是实现不了的,需要转化一下,话不多说,看代码

SELECT
	FROM_UNIXTIME(create_time, '%Y-%m-%d') as day, create_time,
	count( DISTINCT uid ) AS amount 
FROM
	`black_production_user` 
WHERE
	create_time >= 1588262400 
	AND create_time <= 1607529599
	GROUP BY day

以上代码可以按每天分组并统计每天的新增数据量,按月或年的只要修改日期格式就好

mysql groupBy 按日期分组

但上面只统计到了有数据的天数,某天没有时就不返回该天,实际情况中某天没有希望返回0

那按上面的结果在程序中循环赋默认值也可以

其实SQL也可以实现,具体看下面代码:

select day,sum(count) as add_num from (
select count(DISTINCT uid) count, FROM_UNIXTIME(create_time,'%Y-%m-%d') day from `black_production_user` a
where a.create_time >= 1588262400 and a.create_time < 1607529599
GROUP BY day
UNION ALL
select @uu:=0 as count,day from (
select @num:=@num+1 as number,date_format(adddate('2020-05-01 00:00:00', INTERVAL @num DAY),'%Y-%m-%d') as day
from `black_production_user` a ,(select @num:=-1) t
order by day ) rr
) sss GROUP BY sss.day ORDER BY day

这条SQL稍微有点绕,需要自己理解便可,查询结果如下,某天没有数据默认有 0 填充

mysql groupBy 按日期分组

####注意: FROM_UNIXTIME 针对于数据时间存储格式为时间戳, 若库中时间存储的日期格式 : 如 : 2020-12-10 10:03:24 ,这样的使用 DATE_FORMAT 即可

本文地址:https://blog.csdn.net/jxwBlog/article/details/110947004