mysql计算日期时间的差值,DATEDIFF() 和 TIMESTAMPDIFF()函数的用法


前言

当涉及到计算日期或时间之间的差值时,MySQL 提供了两个很好用的函数:DATEDIFF() 和 TIMESTAMPDIFF(),下面简要讲讲用法。


一、DATEDIFF() 函数

DATEDIFF(date1, date2)

本函数接受两个日期做为参数,并返回 date1 和 date2 之间的天数差值(date1-date2),单位是“天”。

举例:SELECT DATEDIFF(‘2024-03-01’, ‘2024-03-21’);

结果是-20,说明’2024-03-01’比’2024-03-21’早20天。

二、TIMESTAMPDIFF() 函数

TIMESTAMPDIFF(unit, start_datetime, end_datetime)

本函数接受三个参数:单位 (unit)、起始日期时间 (start_datetime) 和结束日期时间 (end_datetime),并返回 start_datetime 和 end_datetime 之间的时间差值(end_datetime-start_datetime),这里的结果单位换算成unit。

参数 unit 可以是YEAR、MONTH、DAY、HOUR、MINUTE、SECOND。

举例1:SELECT TIMESTAMPDIFF(DAY, ‘2024-01-01’, ‘2024-01-02’);
结果为1,说明’2024-01-01’比’2024-01-02’早1天。

举例2:SELECT TIMESTAMPDIFF(SECOND, ‘2024-01-01 10:10:10’, ‘2024-01-01 10:10:20’);
结果为20,说明’2024-01-01 10:10:10’比 '2024-01-01 10:10:20’早20秒。


总结

在mysql中,DATEDIFF() 和 TIMESTAMPDIFF()都能用于求两个日期之间的差值。DATEDIFF() 函数仅适用于计算日期之间的差值,而 TIMESTAMPDIFF() 函数除了求日期之间的差值,还能求时间之间的差值,且能够指定时间单位。

  • 6
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值