news 2026/4/16 11:51:00

MySQL中的timediff、timestampdiff、datediff详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL中的timediff、timestampdiff、datediff详解

MySQL 中 TIMEDIFF、TIMESTAMPDIFF、DATEDIFF 函数详解

这三个函数都是 MySQL 中常用的日期时间差值计算函数,但用途、参数和返回值完全不同。以下是详细对比和说明。

函数名称返回值类型功能描述支持的时间单位典型用途
DATEDIFFINT(天数)计算两个日期相差的天数(仅精确到天)天(忽略时间部分)计算两个日期之间相隔多少天
TIMEDIFFTIME 类型计算两个时间/日期时间的差值,返回时:分:秒格式时、分、秒、微秒计算同一日内或跨天的小时级时间差
TIMESTAMPDIFFINT(指定单位)计算两个日期时间相差的完整单位数量(最灵活)YEAR, QUARTER, MONTH, WEEK, DAY, HOUR, MINUTE, SECOND, MICROSECOND 等精确计算任意单位的间隔数量
1. DATEDIFF(expr1, expr2)
  • 语法DATEDIFF(expr1, expr2)
  • 返回值:expr1 − expr2 的天数(整数)。时间部分被忽略。
  • 计算规则:expr1 - expr2,正数表示 expr1 在 expr2 之后。

示例

SELECTDATEDIFF('2025-12-30','2025-12-01');-- 29SELECTDATEDIFF('2025-12-01','2025-12-30');-- -29SELECTDATEDIFF('2025-12-30 10:00:00','2025-12-01 23:59:59');-- 29(时间部分忽略)

适用场景:统计年龄(年份差需结合其他计算)、会员注册天数、订单间隔天数等。

2. TIMEDIFF(expr1, expr2)
  • 语法TIMEDIFF(expr1, expr2)
  • 返回值:TIME 类型,格式为 ‘HHH:MM:SS’(可超过24小时,如 48:00:00,支持负值)。
  • 限制
    • 两个参数都必须是 TIME 或 DATETIME 类型。
    • 结果范围:-838:59:59 到 838:59:59(约34天多)。
    • 如果差值超出范围,返回 NULL。

示例

SELECTTIMEDIFF('2025-12-30 15:30:00','2025-12-30 10:20:30');-- '05:09:30'SELECTTIMEDIFF('10:20:30','15:30:00');-- '-05:09:30'SELECTTIMEDIFF('2025-12-31 12:00:00','2025-12-30 10:00:00');-- '26:00:00'

适用场景:计算工作时长、打卡上下班时间差、会议持续时间等需要精确到秒的时间段。

3. TIMESTAMPDIFF(unit, expr1, expr2)
  • 语法TIMESTAMPDIFF(unit, datetime_expr1, datetime_expr2)
  • 返回值:expr2 − expr1 的指定单位数量(整数)。
  • 注意顺序:是 expr2 - expr1(与前两个函数顺序相反!)。
  • 常用 unit 参数(不区分大小写):
    • MICROSECOND, SECOND, MINUTE, HOUR, DAY, WEEK, MONTH, QUARTER, YEAR

示例

SELECTTIMESTAMPDIFF(DAY,'2025-12-01','2025-12-30');-- 29SELECTTIMESTAMPDIFF(MONTH,'2025-10-15','2025-12-20');-- 2SELECTTIMESTAMPDIFF(HOUR,'2025-12-30 10:00:00','2025-12-31 15:30:00');-- 29SELECTTIMESTAMPDIFF(YEAR,'2020-01-01','2025-12-30');-- 5SELECTTIMESTAMPDIFF(MINUTE,'10:00:00','15:30:45');-- 330

适用场景:最常用!可以精确计算任意单位的时间差,如用户年龄(YEAR)、会员时长(MONTH)、响应时间(SECOND)等。

三者对比总结(记忆口诀)
需求推荐函数原因
只想知道相差多少DATEDIFF最简单,直接返回天数
需要返回时:分:秒格式的时间差TIMEDIFF返回 TIME 类型,适合展示时长
需要精确到任意单位(年/月/日/时/分/秒)TIMESTAMPDIFF(首选)最灵活,单位可自定义,推荐大多数场景使用
常见误区
  1. 参数顺序不一致
    • DATEDIFF 和 TIMEDIFF 是 expr1 - expr2
    • TIMESTAMPDIFF 是 expr2 - expr1(后减前)
  2. DATEDIFF 忽略时间部分,而 TIMESTAMPDIFF(DAY, …) 会考虑完整时间。
  3. 计算年龄时不要直接用 DATEDIFF/365(闰年问题),推荐:
    TIMESTAMPDIFF(YEAR,birth_date,CURDATE())-(DATE_FORMAT(CURDATE(),'%m%d')<DATE_FORMAT(birth_date,'%m%d'))

掌握了这三个函数,你就能轻松处理 MySQL 中绝大部分日期时间差计算需求!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/12 12:37:09

【k8s-1.34.2安装部署】十一.metallb-v0.15.2安装

文章目录简介一.安装metallb二.配置metallb三.验证metallb简介 本章节主要讲解安装metallb-v0.7.1的安装&#xff0c;metallb算是平民版的负载均衡&#xff0c;用于测试、访问量较小的情况还是比较不错的&#xff0c;但是对于请求量比较的时候&#xff0c;由于流量都集中在一个…

作者头像 李华
网站建设 2026/4/14 18:50:32

在Miniconda中安装NLTK进行自然语言处理

在Miniconda中安装NLTK进行自然语言处理 在当今数据驱动的研发环境中&#xff0c;一个常见的困境是&#xff1a;同样的NLP代码在同事的机器上运行正常&#xff0c;却在自己的环境中报错。问题往往不在于代码本身&#xff0c;而在于“环境差异”——不同版本的Python、冲突的依赖…

作者头像 李华
网站建设 2026/4/8 16:16:49

使用Conda管理Python依赖:Miniconda比Anaconda强在哪?

使用Conda管理Python依赖&#xff1a;Miniconda比Anaconda强在哪&#xff1f; 在数据科学和人工智能项目日益复杂的今天&#xff0c;开发环境的混乱问题愈发突出。你有没有遇到过这样的场景&#xff1a;刚跑通一个PyTorch模型&#xff0c;切换到另一个TensorFlow项目时&#x…

作者头像 李华
网站建设 2026/4/16 8:03:40

使用GitHub开源项目测试Miniconda-Python3.10中的PyTorch性能

使用GitHub开源项目测试Miniconda-Python3.10中的PyTorch性能 在深度学习工程实践中&#xff0c;一个常见的痛点是&#xff1a;明明本地跑得飞快的模型&#xff0c;在同事或CI系统上却频繁报错、性能骤降。问题往往不在于代码本身&#xff0c;而在于环境差异——Python版本不对…

作者头像 李华
网站建设 2026/4/15 6:23:33

告别繁琐依赖管理:Miniconda-Python3.10一键部署深度学习环境

告别繁琐依赖管理&#xff1a;Miniconda-Python3.10一键部署深度学习环境 在人工智能项目开发中&#xff0c;你是否曾遇到过这样的场景&#xff1f;刚跑通一个PyTorch模型&#xff0c;准备切换到TensorFlow做对比实验时&#xff0c;却因为CUDA版本冲突导致整个环境崩溃&#xf…

作者头像 李华
网站建设 2026/4/13 17:42:15

我的“C++之旅”(博客之星主题作文)

序章&#xff1a;年初的迷茫 —— 代码与文字的拉扯​ 两年前&#xff0c;我还是个对着 C 指针头疼的编程学习者&#xff1a;白天泡在 IDE 里调试代码&#xff0c;改 bug 改到深夜&#xff0c;想通过博客记录学习心得&#xff0c;却总被 “写得太浅没人看”“技术点讲不透” 的…

作者头像 李华