上一节提到分时间段统计,可是无数据的时候不显示,而此时我们需要让他显示0。

首先我们需要建一个时间表。

CREATE TABLE `my_date` (
`date` date NOT NULL,
PRIMARY KEY (`date`)
)

并且插入一些数据,具体怎么插入有好多种方法,目的是生成我们需要的时间格式,如下

以下就要用到我们的时间表,与我们的数据表进行连接查询了。呃,中间的1你们可以忽略啊!!你们需要看的只有 t 和 count

mysql> select DATE_FORMAT(md.date,'%Y-%m') t,1,count(*) from my_date md left join article a on DATE_FORMAT(md.date,'%Y-%m') = DATE_FORMAT(a.article_time,'%Y-%m') group by t;

+---------+---+----------+
| t | 1 | count(*) |
+---------+---+----------+
| 2015-01 | 1 | 1 |
| 2015-02 | 1 | 1 |
| 2015-03 | 1 | 1 |
| 2015-04 | 1 | 1 |
| 2015-05 | 1 | 1 |
| 2015-06 | 1 | 1 |
| 2015-07 | 1 | 1 |
| 2015-08 | 1 | 1 |
| 2015-09 | 1 | 1 |
| 2015-10 | 1 | 1 |
| 2015-11 | 1 | 1 |
| 2015-12 | 1 | 1 |
| 2016-01 | 1 | 1 |
| 2016-02 | 1 | 1 |
| 2016-03 | 1 | 1 |
| 2016-04 | 1 | 1 |
| 2016-05 | 1 | 1 |
| 2016-06 | 1 | 1 |
| 2016-07 | 1 | 1 |
| 2016-08 | 1 | 22 |
| 2016-09 | 1 | 26 |
| 2016-10 | 1 | 3 |
| 2016-11 | 1 | 1 |
| 2016-12 | 1 | 1 |
+---------+---+----------+
24 rows in set

这里出现了一个问题,无数据的字段变成1了,哈哈哈,什么鬼呀,神经病啊。注意,这里的count(*) 代表统计所有的行,你数据表的那一行无数据,可是我们进行left join 获得的一行不止数据表吧?还有时间表的,时间表那里不为空,是有数据的,所以变成了1。所以我们要把count(*) 变成 count(a.article_id)

mysql> select DATE_FORMAT(md.date,'%Y-%m') t,1,count(a.article_id) from my_date md left join article a on DATE_FORMAT(md.date,'%Y-%m') = DATE_FORMAT(a.article_time,'%Y-%m') group by t;
+---------+---+---------------------+
| t | 1 | count(a.article_id) |
+---------+---+---------------------+
| 2015-01 | 1 | 0 |
| 2015-02 | 1 | 0 |
| 2015-03 | 1 | 0 |
| 2015-04 | 1 | 0 |
| 2015-05 | 1 | 0 |
| 2015-06 | 1 | 0 |
| 2015-07 | 1 | 0 |
| 2015-08 | 1 | 0 |
| 2015-09 | 1 | 0 |
| 2015-10 | 1 | 1 |
| 2015-11 | 1 | 0 |
| 2015-12 | 1 | 0 |
| 2016-01 | 1 | 0 |
| 2016-02 | 1 | 0 |
| 2016-03 | 1 | 0 |
| 2016-04 | 1 | 0 |
| 2016-05 | 1 | 0 |
| 2016-06 | 1 | 0 |
| 2016-07 | 1 | 1 |
| 2016-08 | 1 | 22 |
| 2016-09 | 1 | 26 |
| 2016-10 | 1 | 3 |
| 2016-11 | 1 | 1 |
| 2016-12 | 1 | 1 |
+---------+---+---------------------+
24 rows in set

到这里我们发现,时间表里面有多少时间就查出多少,如果我时间表里面有1亿个那还了得!所以我们要进行限制,比如要查当前年份的每个月数据。

mysql> select DATE_FORMAT(md.date,'%Y-%m') t,1,count(a.article_id) from my_date md left join article a on DATE_FORMAT(md.date,'%Y-%m') = DATE_FORMAT(a.article_time,'%Y-%m') where DATE_FORMAT(md.date,'%Y') = DATE_FORMAT(curdate(),'%Y') group by t;
+---------+---+---------------------+
| t | 1 | count(a.article_id) |
+---------+---+---------------------+
| 2016-01 | 1 | 0 |
| 2016-02 | 1 | 0 |
| 2016-03 | 1 | 0 |
| 2016-04 | 1 | 0 |
| 2016-05 | 1 | 0 |
| 2016-06 | 1 | 0 |
| 2016-07 | 1 | 1 |
| 2016-08 | 1 | 22 |
| 2016-09 | 1 | 26 |
| 2016-10 | 1 | 3 |
| 2016-11 | 1 | 1 |
| 2016-12 | 1 | 1 |
+---------+---+---------------------+
12 rows in set

如果我们要指定年份呢

mysql> select DATE_FORMAT(md.date,'%Y-%m') t,1,count(a.article_id) from my_date md left join article a on DATE_FORMAT(md.date,'%Y-%m') = DATE_FORMAT(a.article_time,'%Y-%m') where DATE_FORMAT(md.date,'%Y') = '' group by t;
+---------+---+---------------------+
| t | 1 | count(a.article_id) |
+---------+---+---------------------+
| 2015-01 | 1 | 0 |
| 2015-02 | 1 | 0 |
| 2015-03 | 1 | 0 |
| 2015-04 | 1 | 0 |
| 2015-05 | 1 | 0 |
| 2015-06 | 1 | 0 |
| 2015-07 | 1 | 0 |
| 2015-08 | 1 | 0 |
| 2015-09 | 1 | 0 |
| 2015-10 | 1 | 1 |
| 2015-11 | 1 | 0 |
| 2015-12 | 1 | 0 |
+---------+---+---------------------+
12 rows in set

那个时间表里面的数据一定要事先生成咯,生成个几十年就够用了,公司说不定活不到那个时候呢哈哈哈,好好笑

下面进行一下每年的统计,到这里我时间表加入了2014年的12个月

mysql> select DATE_FORMAT(md.date,'%Y') t,1,count(a.article_id) from my_date md left join article a on DATE_FORMAT(md.date,'%Y-%m') = DATE_FORMAT(a.article_time,'%Y-%m') group by t;
+------+---+---------------------+
| t | 1 | count(a.article_id) |
+------+---+---------------------+
| 2014 | 1 | 0 |
| 2015 | 1 | 1 |
| 2016 | 1 | 54 |
+------+---+---------------------+
3 rows in set

这个呢,时间表里面有多少年就显示多少年,我们也可以指定、

mysql> select DATE_FORMAT(md.date,'%Y') t,1,count(a.article_id) from my_date md left join article a on DATE_FORMAT(md.date,'%Y-%m') = DATE_FORMAT(a.article_time,'%Y-%m') where DATE_FORMAT(md.date,'%Y') > '' group by t;
+------+---+---------------------+
| t | 1 | count(a.article_id) |
+------+---+---------------------+
| 2015 | 1 | 1 |
| 2016 | 1 | 54 |
+------+---+---------------------+
2 rows in set
mysql> select DATE_FORMAT(md.date,'%Y') t,1,count(a.article_id) from my_date md left join article a on DATE_FORMAT(md.date,'%Y-%m') = DATE_FORMAT(a.article_time,'%Y-%m') where DATE_FORMAT(md.date,'%Y') > '' and DATE_FORMAT(md.date,'%Y') < '' group by t;
+------+---+---------------------+
| t | 1 | count(a.article_id) |
+------+---+---------------------+
| 2015 | 1 | 1 |
+------+---+---------------------+
1 row in set

MySQL时间段查询,无数据补0的更多相关文章

  1. SQL Server中时间段查询和数据类型转换

    不知道什么时候对数据独有情种,也许是因为所学专业的缘故,也许是在多年的工作中的亲身经历,无数据,很多事情干不了,数据精度不够,也很多事情干不了,有一次跟一个朋友开玩笑说,如果在写论文的时候,能有一份独 ...

  2. MySQL如何查询LINESTRING数据

    我有一个提交的命名crm_geo_org,具有以下结构 ipoid INTEGER 11 NOT NULL PRIMARY KEY beginip INTEGER 14 NOT NULL UNSIGN ...

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

    转载自:http://blog.csdn.net/jie11447416/article/details/50887888 1.案例中的数据结构和数据如下 2.在没有解决的时候,是这样的   SELE ...

  4. 报表统计——java实现查询某年某月每天数据,没数据补0

    一般图表绘制例如echarts等,返回数据格式都大同小异.重点是利用sql或者java实现数据格式的转型,接下来是关键部分: 1.前提:提供的工具方法——获取某月有多少天 //通过年份和月份确定该月的 ...

  5. 报表统计——java实现查询某年12个月数据,没数据补0

    一般图表绘制例如echarts等,返回数据格式都大同小异.重点是利用sql或者java实现数据格式的转型,接下来是关键部分: 1.mapper层sql语句,返回统计好的月份与对应月份的数据. < ...

  6. MySQL时间段查询

    现实中我们会遇到统计报表.比如查询当月每一天的数据数量...等等之类的.以下内容就是有关这方面的咯. 首先要知道几个函数 mysql> select now(); //这个是显示的当前时间 +- ...

  7. MySQL分页查询大数据量优化方法

    方法1: 直接使用数据库提供的SQL语句 语句样式: MySQL中,可用如下方法: SELECT * FROM 表名称 LIMIT M,N适应场景: 适用于数据量较少的情况(元组百/千级)原因/缺点: ...

  8. mysql随机查询若干条数据

    条不重复的数据,使用以下: 秒以上 搜索Google,网上基本上都是查询max(id) * rand()来随机获取数据. SELECT *  FROM `table` AS t1 JOIN (SELE ...

  9. 【MySQL】MySQL中查询出数据表中存在重复的值list

    1.目的:查询MySQL数据表中,重复记录的值 2.示例: 3.代码: select serial_num,count(*) as count FROM card_ticket GROUP BY se ...

随机推荐

  1. PHP 模拟 HTTP 基本认证(Basic Authentication)

    当某个页面需要认证才能进行访问时,接到请求后服务器端会在响应头中发送一个 WWW-Authenticate 首部(用来标识认证安全域),语法为 WWW-Authenticate:Basic relam ...

  2. Mac OS X:禁止崩溃报告-CrashReport

    Mac OS X:禁止崩溃报告 崩溃报告就是CrashReport 至于官方的有关CrashReport的文档在Technical Note TN212 . 一般的默认情况下,当一个应用程序因为各种原 ...

  3. get back to the slower clock rate that allows it to save more power

    http://www.howtogeek.com/177790/why-you-cant-use-cpu-clock-speed-to-compare-computer-performance/ Wh ...

  4. C语言 ---- 指针 iOS学习-----细碎知识点总结

    内存的访问形式:1.直接访问:通过变量名进行访问.2.间接访问:先找到变量存放的地址,然后根据地址去访问对应的内存空间. 指针--- // 定义一个整形指针变量,用来存储num1在内存中的地址    ...

  5. Python实例学习-文件备份

    1. 介绍 通过实例学习Python的使用,该实例来自文献[1]中的第11章解决问题. 由于没有搞清楚Win7下如何通过命令行调用zip命令,所以采用7z[2],采用7-zip命令行版本[3],版本号 ...

  6. RestTemplate配置

    什么是RestTemplate? RestTemplate是Spring提供的用于访问Rest服务的客户端,RestTemplate提供了多种便捷访问远程Http服务的方法,能够大大提高客户端的编写效 ...

  7. LINQ教程

    在说LINQ之前必须先说说几个重要的C#语言特性 一:与LINQ有关的语言特性 1.隐式类型 (1)源起 在隐式类型出现之前, 我们在声明一个变量的时候, 总是要为一个变量指定他的类型 甚至在fore ...

  8. scrollViewDidEndScrollingAnimation和scrollViewDidEndDecelerating的区别

    #pragma mark - 监听 /**  *  点击了顶部的标题按钮  */ - (void)titleClick:(XMGTitleButton *)titleButton {     // 修 ...

  9. SpringMVC常用配置-处理程序异常以及404错误

  10. js 将json字符串转换为json对象的方法解析

    推荐: var obj = eval('(' + str + ')'); var last=JSON.stringify(obj); //将JSON对象转化为string字符 例如: JSON字符串: ...