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 转换。不复杂但容易忽略细节。
以上就是如何在mysql中使用日期函数处理时间数据的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/202681.html
微信扫一扫
支付宝扫一扫