MySQL 的时间函数有哪些?如何使用?

数据库 MySQL
本文我们分析了 MySQL 中常用的日期和时间函数,它们在日常工作中有广泛的使用,不过在使用中我们需要注意以下两点.。

在 MySQL中,提供了很多日期和时间函数,那么,在实际工作中,我们该如何选择?这篇文章,我们一起来聊一聊。

从整体上看,MySQL的日期和时间函数可以分为六大类:获取当前日期和时间、提取日期和时间的特定部分、格式化日期和时间、日期和时间的算术操作、提取日期的部分和Unix 时间戳相关函数等。

1. 获取当前日期和时间

获取当前日期和时间的函数包含以下几个常用函数:

(1) NOW() / CURRENT_TIMESTAMP

作用:返回当前的日期和时间。

示例:

SELECT NOW();
-- 输出格式例如:2025-01-05 14:30:00

(2) CURDATE() / CURRENT_DATE

作用:返回当前的日期。

示例:

SELECT CURDATE();
-- 输出格式例如:2025-01-05

(3) CURTIME() / CURRENT_TIME

作用:返回当前的时间。

示例:

SELECT CURTIME();
-- 输出格式例如:14:30:00

2. 提取日期和时间的特定部分

提取日期和时间的特定部分的常用函数包含以下几个:

(1) YEAR(date)

作用:提取年份。

示例:

SELECT YEAR('2025-01-25');
-- 输出:2023

(2) MONTH(date)

作用:提取月份。

示例:

SELECT MONTH('2025-01-25');
-- 输出:10

(3) DAY(date)

作用:提取日期中的天。

示例:

SELECT DAY('2025-01-25');
-- 输出:5

(4) HOUR(time)、MINUTE(time)、SECOND(time)

作用:分别提取时间中的小时、分钟和秒。

示例:

SELECT HOUR('14:30:00'), MINUTE('14:30:00'), SECOND('14:30:00');
-- 输出:14  30  00

3. 格式化日期和时间

格式化日期和时间的常用函数包含以下几个:

(1) DATE_FORMAT(date, format)

作用:按照指定格式格式化日期/时间。

常用格式符:

  • %Y 年份(四位)
  • %m 月份(两位)
  • %d 日(两位)
  • %H 小时(24小时制)
  • %i 分钟
  • %s 秒

示例:

SELECT DATE_FORMAT(NOW(), '%Y年%m月%d日 %H:%i:%s');
-- 输出格式例如:2025年01月15日 14:30:00

(2) STR_TO_DATE(string, format)

作用:将字符串按照指定格式转换为日期/时间类型。

示例:

SELECT STR_TO_DATE('15-01-2025', '%d-%m-%Y');
-- 输出:2025-01-25

4. 日期和时间的算术操作

(1) DATE_ADD(date, INTERVAL expr unit)

作用:在日期上添加指定的时间间隔。

示例:

SELECT DATE_ADD('2025-01-15', INTERVAL 10 DAY);
-- 输出:2025-01-25

(2) DATE_SUB(date, INTERVAL expr unit)

作用:从日期中减去指定的时间间隔。

示例:

SELECT DATE_SUB('2025-03-25', INTERVAL 2 MONTH);
-- 输出:2025-01-25

(3) DATEDIFF(date1, date2)

作用:返回两个日期之间的天数差异。

示例:

SELECT DATEDIFF('2025-01-25', '2025-01-15');
-- 输出:10

(4) TIMESTAMPDIFF(unit, datetime1, datetime2)

作用:返回两个日期之间指定单位的差异。

单位包括:SECOND、MINUTE、HOUR、DAY、MONTH、YEAR 等。

示例:

SELECT TIMESTAMPDIFF(DAY, '2025-01-15', '2025-01-25');
-- 输出:10
SELECT TIMESTAMPDIFF(HOUR, '2025-01-25 10:00:00', '2025-01-25 14:30:00');
-- 输出:4

5. 提取日期的部分

(1) EXTRACT(part FROM date)

作用:提取日期或时间的特定部分。

可提取部分:YEAR、MONTH、DAY、HOUR、MINUTE、SECOND 等。

示例:

SELECT EXTRACT(YEAR FROM '2025-01-25'), EXTRACT(MONTH FROM '2025-01-25');
-- 输出:2025  01

6. Unix 时间戳相关函数

(1) UNIX_TIMESTAMP()

作用:返回当前时间的 Unix 时间戳(秒数)。

示例:

SELECT UNIX_TIMESTAMP();
-- 输出:例如 1696453800

(2) FROM_UNIXTIME(unix_timestamp, format)

作用:将 Unix 时间戳转换为日期和时间格式。

示例:

SELECT FROM_UNIXTIME(1696453800, '%Y-%m-%d %H:%i:%s');
-- 输出:2025-01-25 14:30:00

7. 总结

本文我们分析了 MySQL 中常用的日期和时间函数,它们在日常工作中有广泛的使用,不过在使用中我们需要注意以下两点:

  • 日期格式:确保日期和时间的格式符合 MySQL 的标准格式(如 YYYY-MM-DD 或 YYYY-MM-DD HH:MM:SS),否则可能导致函数解析错误。
  • 时区设置:NOW() 和相关函数受服务器时区设置影响,确保时区配置正确以获取准确的时间。
责任编辑:赵宁宁 来源: 猿java
相关推荐

2024-11-01 06:00:00

2024-12-23 15:58:38

2023-11-19 23:13:56

Kotlin作用域函数

2010-10-11 16:35:54

MySql时间函数

2010-05-06 15:44:08

Oracle Nvl函

2023-03-11 22:22:04

数据库MySQL

2014-11-07 10:05:38

OSPFLSA

2010-11-25 11:01:33

MySQL日期函数

2010-06-03 09:39:24

优化MySQL性能

2010-06-13 15:42:37

MySQL性能优化

2022-03-09 09:39:22

Python函数模块

2022-11-24 13:55:47

React类组件

2022-03-21 21:55:43

Python编程语言

2010-10-11 15:08:44

MySQL conca

2010-10-11 16:23:35

MYSQL BENCH

2010-10-09 16:18:43

MYSQL IFNUL

2024-12-31 07:56:33

Disruptor内存有界队列消费模式

2010-05-31 10:35:12

MySQL数据类型

2010-05-27 13:26:20

MySQL日期时间函数

2009-02-24 16:17:41

日期时间函数
点赞
收藏

51CTO技术栈公众号