共计 12392 个字符,预计需要花费 31 分钟才能阅读完成。
自动写代码机器人,免费开通
丸趣 TV 小编给大家分享一下 MySQL 中日期函数有哪些,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
日期函数类型:
(1)获取当前日期的函数和获取当前时间的函数
(2) 获取当前日期和时间的函数
(3)UNIX 时间戳函数
(4) 返回 UTC 日期的函数和返回 UTC 时间的函数
(5) 获取月份的函数 month(date)和 monthname(date)
(6)获取星期的函数 dayname(d)、dayofweek(d)和 weekday(d)
(7)获取星期数的函数 week(d)和 dayofyear(d)
(8)获取天数的函数 dayofyear(d)和 dayofmonth(d)
(9)获取年份、季度、小时、分钟和秒钟的函数。
(10)获取日期的指定值的函数 extract(type from date)
(11)时间和秒钟转换的函数
(12) 计算日期和时间的函数
(13) 将日期和时间格式化的函数
(相关免费学习推荐:mysql 视频教程)
(1)获取当前日期的函数和获取当前时间的函数
1.curdate()和 current_date()
【例】使用日期函数获取系统当前日期,SQL 语句如下:
mysql select curdate(),current_date(),curdate()+0;+------------+----------------+-------------+| curdate() | current_date() | curdate()+0 |+------------+----------------+-------------+| 2019-08-18 | 2019-08-18 | 20190818 |+------------+----------------+-------------+1 row in set (0.00 sec)
curdate()+ 0 表示将当前日期值转换为数值型。
2.curtime()和 current_time()
【例】使用时间函数获取系统当前时间,SQL 语句如下:
mysql select curtime(),current_time(),curtime()+0;+-----------+----------------+-------------+| curtime() | current_time() | curtime()+0 |+-----------+----------------+-------------+| 17:08:07 | 17:08:07 | 170807 |+-----------+----------------+-------------+1 row in set (0.00 sec)
curtime()+ 0 表示将当前时间值转换为数值型。
(2)获取当前日期和时间的函数
current_timestamp()、localtime()、now()和 sysdate()四个函数作用相同,都是返回当前日期和时间值。
【例】使用日期时间函数获取当前系统时间和日期,SQL 语句如下:
mysql select current_timestamp(),
- localtime(),
- now(),
- sysdate();+---------------------+---------------------+---------------------+---------------------+| current_timestamp() | localtime() | now() | sysdate() |+---------------------+---------------------+---------------------+---------------------+| 2019-08-18 19:10:05 | 2019-08-18 19:10:05 | 2019-08-18 19:10:05 | 2019-08-18 19:10:05 |+---------------------+---------------------+---------------------+---------------------+1 row in set (0.05 sec)
(3)UNIX 时间戳函数
unix_timestamp(date)若为无参数调用, 则返回一个 unix 时间戳 (GMT 之后的秒数,GMT 为格林尼治标准时间 1970.1.1) 作为无符号整数。
date 可以是一个 date 字符串,datetime 字符串、timestamp 或一个当地时间的 YY[YY]MMDD 格式的数字。
1.unix_timestamp(date)
【例】使用 unix_timestamp 函数返回 unix 格式的时间戳,SQL 语句如下:
mysql select unix_timestamp(),unix_timestamp(now()),now();+------------------+-----------------------+---------------------+| unix_timestamp() | unix_timestamp(now()) | now() |+------------------+-----------------------+---------------------+| 1566127316 | 1566127316 | 2019-08-18 19:21:56 |+------------------+-----------------------+---------------------+1 row in set (0.05 sec)
from_unixtime()函数吧 unix 时间戳转换为普通格式的时间, 与 unix_timestamp(date)函数互为反函数。
2.from_unixtime(date)
【例】使用 from_unixtime 函数将 unix 时间戳转换为普通格式时间,SQL 语句如下:
mysql select from_unixtime(1566127316 +-----------------------------+| from_unixtime( 1566127316) |+-----------------------------+| 2019-08-18 19:21:56.000000 |+-----------------------------+1 row in set (0.00 sec)
(4)返回 UTC 日期的函数和返回 UTC 时间的函数。
1.UTC_DATE()
【例】使用 utc_date()函数返回当前 UTC 日期值,SQL 语句如下:
mysql select utc_date(),utc_date()+0;+------------+--------------+| utc_date() | utc_date()+0 |+------------+--------------+| 2019-08-18 | 20190818 |+------------+--------------+1 row in set (0.05 sec)
2.UTC_TIME()
【例】使用 UTC_TIME()函数返回当前 UTC 时间值,SQL 语句如下:
mysql select utc_time(),utc_time()+0;+------------+--------------+| utc_time() | utc_time()+0 |+------------+--------------+| 11:32:27 | 113227 |+------------+--------------+1 row in set (0.00 sec)
(5)获取月份的函数 month(date)和 monthname(date)
1.month(date)
【例】使用 month()函数返回指定日期中的月份,SQL 语句如下:
mysql select month(2019-08-18 +---------------------+| month( 2019-08-18) |+---------------------+| 8 |+---------------------+1 row in set (0.00 sec)
2.monthname(date)
【例】使用 monthname()函数返回指定日期中的月份名称,SQL 语句如下:
mysql select monthname(2019-08-18 +-------------------------+| monthname( 2019-08-18) |+-------------------------+| August |+-------------------------+1 row in set (0.00 sec)
(6)获取星期的函数 dayname(d)、dayofweek(d)和 weekday(d)
1.dayname(d)
【例】使用 dayname()函数返回指定日期的工作日名称,SQL 语句如下:
mysql select dayname(2019-08-18 +-----------------------+| dayname( 2019-08-18) |+-----------------------+| Sunday |+-----------------------+1 row in set (0.00 sec)
2.dayofweek(d)
【例】使用 dayofweek()函数返回日期对应的周索引,SQL 语句如下:
mysql select dayofweek(2019-08-18 +-------------------------+| dayofweek( 2019-08-18) |+-------------------------+| 1 |+-------------------------+1 row in set (0.00 sec)
3.weekday(d)
weekday(d)返回 d 对应的工作日索引:0 代表周一,1 代代表周二,…6 代表周日。
【例】使用 weekday()函数返回日期对应的工作日索引,SQL 语句如下:
mysql select weekday(2019-08-18 19:40:00),
- weekday(2019-08-18 +--------------------------------+-----------------------+| weekday( 2019-08-18 19:40:00) | weekday(2019-08-18) |+--------------------------------+-----------------------+| 6 | 6 |+--------------------------------+-----------------------+1 row in set (0.00 sec)
(7)获取星期数的函数 week(d)和 dayofyear(d)
week(d)计算日期 d 是一年中第几周,双参形式允许指定该星期是否起始于周日或周一,若 Mode 参数被忽略,使用 default_week_format 系统自变量的值。
1.week(d)
【例】使用 week()函数查询指定日期是一年中的第几周,SQL 语句如下:
mysql select week(2019-08-18),week(2019-08-18 ,0),week(2019-08-18 ,1);+--------------------+----------------------+----------------------+| week(2019-08-18) | week(2019-08-18 ,0) | week(2019-08-18 ,1) |+--------------------+----------------------+----------------------+| 33 | 33 | 33 |+--------------------+----------------------+----------------------+1 row in set (0.05 sec
2.weekofyear(d)
【例】使用 weekofyear()查询指定日期是一年中的第几周,SQL 语句如下:
mysql select week(2019-08-18 ,3),weekofyear(2019-08-18 +----------------------+--------------------------+| week( 2019-08-18 ,3) | weekofyear(2019-08-18) |+----------------------+--------------------------+| 33 | 33 |+----------------------+--------------------------+1 row in set (0.05 sec)
(8)获取天数的函数 dayofyear(d)和 dayofmonth(d)
1.dayofyear()
【例】使用 dayofyear()函数返回指定日期在一年中的位置,SQL 语句如下:
mysql select dayofyear(2019-08-18 +-------------------------+| dayofyear( 2019-08-18) |+-------------------------+| 230 |+-------------------------+1 row in set (0.00 sec)
2.dayofmonth()
【例】使用 dayofmonth()函数返回指定日期在一个月中的位置,SQL 语句如下;
mysql select dayofmonth(2019-08-18 +--------------------------+| dayofmonth( 2019-08-18) |+--------------------------+| 18 |+--------------------------+1 row in set (0.00 sec)
(9)获取年份、季度、小时、分钟和秒钟的函数。
1.YEAR(date)
【例】使用 year()函数返回指定日期对应的年份,SQL 语句如下:
mysql select year(19-08-18),year(98-02-19 +------------------+------------------+| year( 19-08-18) | year(98-02-19) |+------------------+------------------+| 2019 | 1998 |+------------------+------------------+1 row in set (0.05 sec)
2.QUARTER(date)
【例】使用 quarter()函数返回指定日期对应的季度,SQL 语句如下:
mysql select quarter(19-08-18 +---------------------+| quarter( 19-08-18) |+---------------------+| 3 |+---------------------+1 row in set (0.00 sec)
3.MINUTE(time)
【例】使用 minute()函数返回指定时间的分钟值,SQL 语句如下:
mysql select minute(19-08-18 20:07:00 +-----------------------------+| minute( 19-08-18 20:07:00) |+-----------------------------+| 7 |+-----------------------------+1 row in set (0.00 sec)
4.SECOND(time)
【例】使用 second()函数返回指定时间的秒值,SQL 语句如下:
mysql select second(20:07:00 +--------------------+| second( 20:07:00) |+--------------------+| 0 |+--------------------+1 row in set (0.00 sec)
(10)获取日期的指定值的函数 extract(type from date)
【例】使用 extract(type from date)函数提取日期或时间值。
mysql select extract(year from 2019-08-18) as col1,
- extract(year_month from 2019-08-18 20:46:01) as col2,
- extract(day_minute from 2019-08-18 20:46:01) as col3;+------+--------+--------+| col1 | col2 | col3 |+------+--------+--------+| 2019 | 201908 | 182046 |+------+--------+--------+1 row in set (0.00 sec)
(11)时间和秒钟转换的函数
1.time_to_sec(time)
time_to_sec(time)返回已经转化为秒的 time 参数。转换公式为:小时 x3600+ 分钟 *60+ 秒。
【例】使用 time_to_sec 函数将时间值转换为秒值。
mysql select time_to_sec(20:34:00 +-------------------------+| time_to_sec( 20:34:00) |+-------------------------+| 74040 |+-------------------------+1 row in set (0.00 sec)
2.sec_to_time(seconds)
sec_to_time 函数返回值加上 0 值之后变成了小数值。
time_to_sec 正好和 sec_to_time 互为反函数。
【例】使用 sec_to_time()函数将秒值转换为时间格式,SQL 语句如下;
mysql select sec_to_time(2345),sec_to_time(2345)+0,
- time_to_sec(20:36:00),sec_to_time(74040 +-------------------+---------------------+-------------------------+----------------------+| sec_to_time(2345) | sec_to_time(2345)+0 | time_to_sec(20:36:00) | sec_to_time(74040) |+-------------------+---------------------+-------------------------+----------------------+| 00:39:05 | 3905 | 74160 | 20:34:00.000000 |+-------------------+---------------------+-------------------------+----------------------+1 row in set (0.05 sec)
(12)计算日期和时间的函数。
MySQL 中计算日期和时间的格式:
1.date_add(date,interval expr type)和 adddate(date,interval expr type)两个函数的作用相同, 执行日期的加运算:
【例】使用 date_add()和 adddate()函数执行日期加操作,SQL 语句如下:
mysql select date_add(2019-08-18 23:59:59 ,interval 1 second) as col1,
- adddate(2019-08-18 23:59:59 ,interval 1 second) as col2,
- date_add(2019-08-18 23:59:59 ,interval 1:1 minute_second) as col3;+---------------------+---------------------+---------------------+| col1 | col2 | col3 |+---------------------+---------------------+---------------------+| 2019-08-19 00:00:00 | 2019-08-19 00:00:00 | 2019-08-19 00:01:00 |+---------------------+---------------------+---------------------+1 row in set (0.05 sec)
2.date_sub(date,interval expr type)和 subdate(date,interval expr type)两个函数作用相同,执行日期的减运算:
【例】使用 date_sub 和 subdate 函数执行日期减操作,SQL 语句如下:
mysql select date_sub(2019-08-18 ,interval 31 day) as col1,
- subdate(2019-08-18 ,interval 31 day) as col2,
- date_sub(2019-08-18 21:15:10 ,interval 0 0:1:1 day_second) as col3;+------------+------------+---------------------+| col1 | col2 | col3 |+------------+------------+---------------------+| 2019-07-18 | 2019-07-18 | 2019-08-18 21:14:09 |+------------+------------+---------------------+1 row in set (0.00 sec)
3.addtime(date,expr)函数将 expr 值添加到 date, 并返回修改后的值,date 是一个日期或者日期时间表达式, 而 expr 是一个时间表达式。
【例】使用 addtime 进行时间加操作,SQL 语句如下;
mysql select addtime(2019-08-18 21:59:59 , 1:1:1),addtime(02:02:02 , 02:00:00 +----------------------------------------+--------------------------------+| addtime( 2019-08-18 21:59:59 , 1:1:1) | addtime(02:02:02 , 02:00:00) |+----------------------------------------+--------------------------------+| 2019-08-18 23:01:00 | 04:02:02 |+----------------------------------------+--------------------------------+1 row in set (0.05 sec)
4.subtime(date,expr)函数将 date 减去 expr 值,并返回修改后的值,date 是一个日期或者日期时间表达式,expr 是一个时间表达式。
【例】使用 subtime()函数执行减操作,SQL 语句如下:
mysql select subtime(2019-08-18 21:59:59 , 1:1:1),subtime(02:02:02 , 02:00:00 +----------------------------------------+--------------------------------+| subtime( 2019-08-18 21:59:59 , 1:1:1) | subtime(02:02:02 , 02:00:00) |+----------------------------------------+--------------------------------+| 2019-08-18 20:58:58 | 00:02:02 |+----------------------------------------+--------------------------------+1 row in set (0.00 sec)
5.datediff(date1,date2)返回起始时间 date1 和结束时间 date2 之间的天数,date1 和 date2 为日期或 date-and-time 表达式。计算中只用到这些值的日期部分。
【例】使用 datediff()函数计算两个日期之间的间隔天数,SQL 语句如下;
mysql select datediff(2019-08-18 21:59:59 , 2018-07-18) as col1,
- datediff(2019-08-18 22:00:00 , 2019-08-20) as col2;+------+------+| col1 | col2 |+------+------+| 396 | -2 |+------+------+1 row in set (0.00 sec)
(13)将日期和时间格式化的函数。
DATE_FORMAT 时间日期格式:
1.date_format()
【例】使用 date_format()函数格式化输出日期和时间值,SQL 语句如下:
mysql select date_format(2019-08-18 23:33:00 , %w %m %y) as col1,
- date_format(2019-08-18 23:33:00 , %D %y %a %d %m %b %j) as col2;+---------+---------------------------+| col1 | col2 |+---------+---------------------------+| 0 08 19 | 18th 19 Sun 18 08 Aug 230 |+---------+---------------------------+1 row in set (0.05 sec)
2.time_format()
【例】使用 time_format(time,format)函数格式化输入时间值,SQL 语句如下:
mysql select time_format(23:39:30 , %H %k %h %I %l +------------------------------------------+| time_format( 23:39:30 , %H %k %h %I %l) |+------------------------------------------+| 23 23 11 11 11 |+------------------------------------------+1 row in set (0.00 sec)
3.get_format()
get_format 返回的格式字符串:
【例】使用 get_format()函数显示不同格式化类型下的格式字符串,SQL 语句如下:
mysql select get_format(date, eur),get_format(date, usa +------------------------+------------------------+| get_format(date, eur) | get_format(date, usa) |+------------------------+------------------------+| %d.%m.%Y | %m.%d.%Y |+------------------------+------------------------+1 row in set (0.05 sec)
【例】在 date_format()函数中, 使用 get_format 函数返回的显示格式字符串来显示指定的日期值,SQL 语句如下:
mysql select date_format(2019-08-19 23:41:30 ,get_format(date, usa +-----------------------------------------------------------+| date_format( 2019-08-19 23:41:30 ,get_format(date, usa)) |+-----------------------------------------------------------+| 08.19.2019 |+-----------------------------------------------------------+1 row in set (0.00 sec)
看完了这篇文章,相信你对“MySQL 中日期函数有哪些”有了一定的了解,如果想了解更多相关知识,欢迎关注丸趣 TV 行业资讯频道,感谢各位的阅读!
向 AI 问一下细节