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;
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;
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') = '2015' group by t;
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') > '2014' 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') > '2014' and DATE_FORMAT(md.date,'%Y') < '2016' group by t;