如何在mysql中使用日期函数处理时间数据

来源:这里教程网 时间:2026-02-28 20:12:33 作者:

在MySQL中处理时间数据时,日期函数能帮助你轻松完成时间的提取、格式化、计算和比较。掌握常用函数可以高效地应对各种时间相关操作。

获取当前时间

MySQL提供了几个函数来获取系统当前的时间或日期:

NOW():返回当前的日期和时间,格式为 'YYYY-MM-DD HH:MM:SS' CURDATE():只返回当前日期,如 '2025-04-05' CURTIME():只返回当前时间,如 '14:30:25' 示例:
SELECT NOW(), CURDATE(), CURTIME();

提取日期部分信息

从日期时间字段中提取年、月、日等特定部分非常常见:

YEAR(date):提取年份 MONTH(date):提取月份(1-12) DAY(date):提取天数 HOUR(time)MINUTE(time)SECOND(time):提取时分秒 DATE(date):仅提取日期部分,忽略时间 TIME(time):仅提取时间部分 示例:
SELECT 
  YEAR('2025-04-05 14:30:25') AS 年份,
  MONTH('2025-04-05 14:30:25') AS 月份,
  DAY('2025-04-05 14:30:25') AS 日;

格式化日期输出

使用 DATE_FORMAT() 可以按自定义格式显示日期:

%Y:四位年份 %m:两位月份(01-12) %d:两位日期(01-31) %H:24小时制小时 %i:分钟 %s:秒 示例:
SELECT DATE_FORMAT(NOW(), '%Y年%m月%d日 %H:%i') AS 格式化时间;

结果可能为:

2025年04月05日 14:30

日期计算与间隔操作

MySQL支持对日期进行加减运算,常用于统计或预警场景:

DATE_ADD(date, INTERVAL expr unit):给日期增加时间间隔 DATE_SUB(date, INTERVAL expr unit):减少时间间隔 DATEDIFF(date1, date2):计算两个日期之间的天数差 TIMESTAMPDIFF(unit, date1, date2):按指定单位(如DAY、MONTH、YEAR)计算时间差 示例:
-- 7天后的日期
SELECT DATE_ADD(CURDATE(), INTERVAL 7 DAY);
<p>-- 计算两个日期相差多少天
SELECT DATEDIFF('2025-04-10', '2025-04-05'); -- 返回 5</p><p>-- 计算年龄(按年差)
SELECT TIMESTAMPDIFF(YEAR, '1990-03-15', CURDATE());

基本上就这些。熟练使用这些函数后,无论是做报表统计、筛选某时间段的数据,还是计算用户活跃周期,都会变得简单直接。注意字段类型是 DATE 或 DATETIME 才能正确参与运算,字符串需要先用 STR_TO_DATE 转换。不复杂但容易忽略细节。

相关推荐