首页 > 技术文章 > MySQL时间段查询

LUA123 2016-12-09 20:15 原文

现实中我们会遇到统计报表。比如查询当月每一天的数据数量。。。等等之类的。以下内容就是有关这方面的咯。

 

首先要知道几个函数

mysql> select now();    //这个是显示的当前时间
+---------------------+
| now()               |
+---------------------+
| 2016-12-09 18:39:57 |
+---------------------+
1 row in set

mysql> select curdate();  //这个是当前日期
+------------+
| curdate()  |
+------------+
| 2016-12-09 |
+------------+
1 row in set
mysql> select date(now());  //当前时间格式化为日期
+-------------+
| date(now()) |
+-------------+
| 2016-12-09  |
+-------------+
1 row in set

mysql> select month(now());  //当前时间格式化为月份
+--------------+
| month(now()) |
+--------------+
|           12 |
+--------------+
1 row in set

mysql> select year(now());  //当前时间格式化为年份
+-------------+
| year(now()) |
+-------------+
|        2016 |
+-------------+
1 row in set

以上都是简单的东西,以下主要用的是DATE_FORMAT函数

MySQL DATE_FORMAT()

DATE_FORMAT(date,format)
date 参数是合法的日期。format 规定日期/时间的输出格式。
可以使用的格式有:
格式    描述
%a    缩写星期名
%b    缩写月名
%c    月,数值
%D    带有英文前缀的月中的天
%d    月的天,数值(00-31)
%e    月的天,数值(0-31)
%f    微秒
%H    小时 (00-23)
%h    小时 (01-12)
%I    小时 (01-12)
%i    分钟,数值(00-59)
%j    年的天 (001-366)
%k    小时 (0-23)
%l    小时 (1-12)
%M    月名
%m    月,数值(00-12)
%p    AM 或 PM
%r    时间,12-小时(hh:mm:ss AM 或 PM)
%S    秒(00-59)
%s    秒(00-59)
%T    时间, 24-小时 (hh:mm:ss)
%U    周 (00-53) 星期日是一周的第一天
%u    周 (00-53) 星期一是一周的第一天
%V    周 (01-53) 星期日是一周的第一天,与 %X 使用
%v    周 (01-53) 星期一是一周的第一天,与 %x 使用
%W    星期名
%w    周的天 (0=星期日, 6=星期六)
%X    年,其中的星期日是周的第一天,4 位,与 %V 使用
%x    年,其中的星期一是周的第一天,4 位,与 %v 使用
%Y    年,4%y    年,2 位

DATA_SUB函数


定义和用法
DATE_SUB() 函数从日期减去指定的时间间隔。

语法
DATE_SUB(date,INTERVAL expr type)
date 参数是合法的日期表达式。expr 参数是您希望添加的时间间隔。

type 参数可以是下列值:

Type 值 
MICROSECOND 
SECOND 
MINUTE 
HOUR 
DAY 
WEEK 
MONTH 
QUARTER 
YEAR 
SECOND_MICROSECOND 
MINUTE_MICROSECOND 
MINUTE_SECOND 
HOUR_MICROSECOND 
HOUR_SECOND 
HOUR_MINUTE 
DAY_MICROSECOND 
DAY_SECOND 
DAY_MINUTE 
DAY_HOUR 
YEAR_MONTH 

更详细的参考W3cSchool:Date函数

 

例子1:查询一个表,从当前年份开始,向后退12年,每一年的数据量。(如果有的年份无数据就不会显示)

mysql> select count(*),DATE_FORMAT(a.article_time,'%Y') t from article a where DATE_FORMAT(a.article_time,'%Y') > DATE_FORMAT(DATE_SUB(now(),INTERVAL 12 YEAR),'%Y') group by t;
+----------+------+
| count(*) | t    |
+----------+------+
|        1 | 2015 |
|       54 | 2016 |
+----------+------+
2 rows in set

 

例子2:查询一个表,在当前年份的每一个月数据量(如果无数据就不会显示)

mysql> select count(*),DATE_FORMAT(a.article_time,'%Y-%m') t from article a where DATE_FORMAT(a.article_time,'%Y') = DATE_FORMAT(now(),'%Y') group by t;
+----------+---------+
| count(*) | t       |
+----------+---------+
|        1 | 2016-07 |
|       22 | 2016-08 |
|       26 | 2016-09 |
|        3 | 2016-10 |
|        1 | 2016-11 |
|        1 | 2016-12 |
+----------+---------+
6 rows in set

 

例子3:查询某个月的每一天的数据量。(如果没有数据就不会显示)

mysql> select count(*),DATE_FORMAT(a.article_time,'%Y-%m-%d') t from article a where DATE_FORMAT(a.article_time,'%Y-%m') = '2016-09' group by t;
+----------+------------+
| count(*) | t          |
+----------+------------+
|       22 | 2016-09-03 |
|        2 | 2016-09-21 |
|        1 | 2016-09-22 |
|        1 | 2016-09-27 |
+----------+------------+
4 rows in set

 

推荐阅读