MySQL常用日期函数包括:NOW()、CURDATE()、CURTIME()获取当前时间;YEAR()、MONTH()、DAY()等提取日期部分;DATE_FORMAT()自定义格式化输出;DATE_ADD()、DATE_SUB()进行日期加减;DATEDIFF()和TIMESTAMPDIFF()计算日期间隔,结合正确数据类型可高效处理时间相关操作。

在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() 可以按自定义格式显示日期:
基于Intranet/Internet 的Web下的办公自动化系统,采用了当今最先进的PHP技术,是综合大量用户的需求,经过充分的用户论证的基础上开发出来的,独特的即时信息、短信、电子邮件系统、完善的工作流、数据库安全备份等功能使得信息在企业内部传递效率极大提高,信息传递过程中耗费降到最低。办公人员得以从繁杂的日常办公事务处理中解放出来,参与更多的富于思考性和创造性的工作。系统力求突出体系结构简明
- %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);-- 计算两个日期相差多少天 SELECT DATEDIFF('2025-04-10', '2025-04-05'); -- 返回 5
-- 计算年龄(按年差) SELECT TIMESTAMPDIFF(YEAR, '1990-03-15', CURDATE());
基本上就这些。熟练使用这些函数后,无论是做报表统计、筛选某时间段的数据,还是计算用户活跃周期,都会变得简单直接。注意字段类型是 DATE 或 DATETIME 才能正确参与运算,字符串需要先用 STR_TO_DATE 转换。不复杂但容易忽略细节。









