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

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() 可以按自定义格式显示日期:

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