在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 转换。不复杂但容易忽略细节。
