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

MYSQL常用日期和时间函数

程序员文章站 2022-05-30 18:24:33
...

“今夜偏知春气暖,虫声新透绿窗纱”
有时我们可能会遇到这样的需求:当前时间是多少、下个月的今天是星期几、统计截止到当前日期前 3 天的收入总和等。这些需求就需要日期和时间函数来实现。
CURDATE()函数:返回当前日期,只包含年月日。

mysql> select CURDATE();
+------------+
| CURDATE() |
+------------+
| 2007-07-11 |
+------------+
1 row in set (0.03 sec)

CURTIME()函数:返回当前时间,只包含时分秒。

mysql> select CURTIME();
+-----------+
| CURTIME() |
+-----------+
| 14:13:46 |
+-----------+
1 row in set (0.00 sec)

NOW()函数:返回当前的日期和时间,年月日时分秒全都包含。

mysql> select NOW();
+---------------------+
| NOW() |
+---------------------+
| 2007-07-11 14:14:06 |
+---------------------+
1 row in set (0.00 sec)

UNIX_TIMESTAMP(date)函数:返回日期 date 的 UNIX 时间戳。

mysql> select UNIX_TIMESTAMP(now());
+-----------------------+
| UNIX_TIMESTAMP(now()) |
+-----------------------+
| 1184134516 |
+-----------------------+
1 row in set (0.02 sec)

FROM_UNIXTIME ( unixtime ) 函 数 : 返 回 UNIXTIME 时 间 戳 的 日 期 值 , 和UNIX_TIMESTAMP(date)互为逆操作。

mysql> select FROM_UNIXTIME(1184134516) ;
+---------------------------+
| FROM_UNIXTIME(1184134516) |
+---------------------------+
| 2007-07-11 14:15:16 |
+---------------------------+
1 row in set (0.00 sec)

WEEK(DATE)和 YEAR(DATE)函数:前者返回所给的日期是一年中的第几周,后者返回所给的日期是哪一年。

mysql> select WEEK(now()),YEAR(now());
+-------------+-------------+
| WEEK(now()) | YEAR(now()) |
+-------------+-------------+
| 27 | 2007 |
+-------------+-------------+
1 row in set (0.02 sec)

HOUR(time)和 MINUTE(time)函数:前者返回所给时间的小时,后者返回所给时间的分钟。

mysql> select HOUR(CURTIME()),MINUTE(CURTIME());
+-----------------+-------------------+
| HOUR(CURTIME()) | MINUTE(CURTIME()) |
+-----------------+-------------------+
| 14 | 18 |
+-----------------+-------------------+
1 row in set (0.00 sec)

MONTHNAME(date)函数:返回 date 的英文月份名称。

mysql> select MONTHNAME(now());
+------------------+
| MONTHNAME(now()) |
+------------------+
| July |
+------------------+
1 row in set (0.00 sec)

DATE_FORMAT(date,fmt)函数:按字符串 fmt 格式化日期 date 值,此函数能够按指定的格式显示日期,

格式符  格式说明
%S,%s   两位数字形式的秒(00,01,...,59)
%i      两位数字形式的分(00,01,...,59)
%H      两位数字形式的小时,24 小时(00,01,...,23)
%h,%I   两位数字形式的小时,12 小时(01,02,...,12)
%k      数字形式的小时,24 小时(0,1,...,23)
%l      数字形式的小时,12 小时(1,2,...,12)
%T      24 小时的时间形式(hh:mm:ss)
%r      12 小时的时间形式(hh:mm:ssAM 或 hh:mm:ssPM)
%p      AM 或 PM
%W      一周中每一天的名称(Sunday,Monday,...,Saturday)
%a      一周中每一天名称的缩写(Sun,Mon,...,Sat)
%d      两位数字表示月中的天数(00,01,...,31)
%e      数字形式表示月中的天数(1,2...,31)
%D      英文后缀表示月中的天数(1st,2nd,3rd,...)
%w      以数字形式表示周中的天数                     (0=Sunday,1=Monday,...,6=Saturday)
%j      以 3 位数字表示年中的天数(001,002,...,366)
%U      周(0,1,52),其中 Sunday 为周中的第一天
%u      周(0,1,52),其中 Monday 为周中的第一天
%M      月名(January,February,...,December)
%b      缩写的月名(January,February,...,December)
%m      两位数字表示的月份(01,02,...,12)
%c      数字表示的月份(1,2,...,12)
%Y      4 位数字表示的年份
%y      两位数字表示的年份
%%      直接值“%”

下面的例子将当前时间显示为“月,日,年”格式:

mysql> select DATE_FORMAT(now(),'%M,%D,%Y');
+-------------------------------+
| DATE_FORMAT(now(),'%M,%D,%Y') |
+-------------------------------+
| July,11th,2007 |
+-------------------------------+
1 row in set (0.00 sec)

DATE_ADD(date,INTERVAL expr type)函数:返回与所给日期 date 相差 INTERVAL 时间段的日期。其中 INTERVAL 是间隔类型关键字,expr 是一个表达式,这个表达式对应后面的类型,type是间隔类型,MySQL 提供了 13 种间隔类型

表达式类型   描述      格式
HOUR        小时      hh
MINUTE      分       mm
SECOND      秒   ss
YEAR        年   YY
MONTH       月   MM
DAY         日   DD
YEAR_MONTH  年和月  YY-MM
DAY_HOUR    日和小时  DD hh
DAY_MINUTE  日和分钟  DD hh:mm
DAY_ SECOND  日和秒  DD hh:mm:ss
HOUR_MINUTE  小时和分  hh:mm
HOUR_SECOND  小时和秒  hh:ss
MINUTE_SECOND  分钟和秒  mm:ss

来看一个具体的例子,在这个例子中第 1 列返回了当前日期时间,第 2 列返回距离当前日期31 天后的日期时间,第 3 列返回距离当前日期一年两个月后的日期时间。

mysql> select now() current,date_add(now(),INTERVAL 31 day) after31days,
date_add(now(),INTERVAL '1_2' year_month) after_oneyear_twomonth;
+---------------------+---------------------+------------------------+
| current | after31days | after_oneyear_twomonth |
+---------------------+---------------------+------------------------+
| 2007-09-03 11:30:48 | 2007-10-04 11:30:48 | 2008-11-03 11:30:48 |
+---------------------+---------------------+------------------------+
1 row in set (0.01 sec)

同样也可以用负数让它返回之前的某个日期时间,如下第 1 列返回了当前日期时间,第 2列返回距离当前日期 31 天前的日期时间,第 3 列返回距离当前日期一年两个月前的日期时间。

mysql> select now() current,date_add(now(),INTERVAL -31 day) after31days,date_a
dd(now(),INTERVAL '-1_-2' year_month) after_oneyear_twomonth;
+---------------------+---------------------+------------------------+
| current | after31days | after_oneyear_twomonth |
+---------------------+---------------------+------------------------+
| 2007-09-03 11:36:35 | 2007-08-03 11:36:35 | 2006-07-03 11:36:35 |
+---------------------+---------------------+------------------------+
1 row in set (0.00 sec)

DATEDIFF(date1,date2)函数:用来计算两个日期之间相差的天数。
下面的例子计算出当前距离 2008 年 8 月 8 日的奥运会开幕式还有多少天:

mysql> select DATEDIFF('2008-08-08',now());
+------------------------------+
| DATEDIFF('2008-08-08',now()) |
+------------------------------+
| 328 |
+------------------------------+
1 row in set (0.01 sec)