Mysql按日期分组(group by)查询统计的时候,没有数据补0的解决办法

转载自:http://blog.csdn.net/jie11447416/article/details/50887888java

一、案例中的数据结构和数据以下spring

 

二、在没有解决的时候,是这样的sql

 1 SELECT date(downtime) AS dday, count(*) AS num FROM re_device GROUP BY dday 数据结构

获得以下结果,若是那天没有数据,那麽就会没有记录 mvc

咱们看到,时间不连续,没有2016-3-05这一天的,这样原本不是问题,可是,我拿出来的数据,还要画出图表呀,没有固然不行,咱们须要的是下面这个样子的。 spa

简单的说就是,没有数据,就要补充一个0..net

 

三、下面咱们讲实现code

咱们要生成一个日历的表,而后和原来的数据,联合查询,说到这里,你们就知道很low了,可是,限于我水平有限,研究这个问题,半天,这个是我找到的比较好的一种实现方式。若是你又更好的,也请你给我说下。 
执行下面的sql,直接诶生成日历的表(calendar)对象

CREATE TABLE num (i int);-- 建立一个表用来储存0-9的数字 INSERT INTO num (i) VALUES (0), (1), (2), (3), (4), (5), (6), (7), (8), (9);-- 生成0-9的数字,方便之后计算时间 CREATE TABLE if not exists calendar(datelist date); -- 生成一个存储日期的表,datalist是字段名 -- 这里是生成并插入日期数据 INSERT INTO calendar(datelist) SELECT adddate( ( -- 这里的起始日期,你能够换成当前日期 DATE_FORMAT("2016-1-1", '%Y-%m-%d') ), numlist.id ) AS `date` FROM ( SELECT n1.i + n10.i * 10 + n100.i * 100 + n1000.i * 1000+ n10000.i * 10000 AS id FROM num n1 CROSS JOIN num AS n10 CROSS JOIN num AS n100 CROSS JOIN num AS n1000 CROSS JOIN num AS n10000 ) AS numlist;

这里我用了100000条记录,算出来到2289年了,彻底够用了,到那个时候,出问题,我也管不了了。blog

完成以后,请删除num的零时表

四、联合查询

 1 SELECT  2  date(dday) ddate,  3     count(*) - 1 as num  4 FROM  5  (  6  SELECT  7  datelist as dday  8  FROM  9  calendar 10             -- 这里是限制返回最近30天的数据 11             where  DATE_SUB(CURDATE(), INTERVAL 30 DAY) <= date(datelist)&&date(datelist)<=CURDATE() 12  UNION ALL 13  SELECT 14  downtime 15  FROM 16  re_device 17  ) a 18 GROUP BY ddate

五、其余解决方法 
固然,应该还有其余的解决方案,可是博主就没有去写了,有时间能够去写一下。 
我用的spring mvc,因此,也仍是能够在java代码中补充完整的,由于数据返回的是个map对象,那麽咱们要遍历这个对象,直接用calendar对象,生成日期做为key来遍历,若是没有数据,就put进去一个0,而后在限制一下,须要多少天的,就能够了。数据就完整了。 
可是这样也有一个问题,那就是map里的数据顺序会有问题,因此,使用的时候,也必须是生成calendar对象,而后构造出来日期做为key来遍历。或者用Collections.sort()排序一下。

我我的以为,仍是上数据直接生成得比较好一点。

相关文章
相关标签/搜索