mysql中timestampdiff()函数与datediff()函数区别

mysql中timestampdiff函数与datediff函数区别

结论

两个函数以天为单位的区别,timestampdiff()函数时间差小于48小时的计数为1,datediff()函数以开始时间为第一天,第三天0点之前为1,0点之后为2。

详细说明

测试环境为mysql版本为:8.0.18
1:timestampdiff 测试结果为2的时间组:
在这里插入图片描述
此组数据使用datediff 测试结果为同样为2。

2:timestampdiff 测试结果为1的时间组:
timestampdiff测试为2,datediff测试为1
此组数据使用datediff 测试结果为2。

下面用两组sql代码以及结果来说明

select datediff(‘2023-06-27 23:59:59’,‘2023-06-26 9:01:22’) #结束时间为第二天23:59:59,结果为1
select datediff(‘2023-06-28 00:00:00’,‘2023-06-26 9:01:22’) #结束时间为第三天0点,结果为2
select datediff(‘2023-06-28 09:01:21’,‘2023-06-26 9:01:22’) #结束时间为第三天,结果为2
select datediff(‘2023-06-28 09:01:22’,‘2023-06-26 9:01:22’) #结束时间为第三天,结果为2

select timestampdiff(day,‘2023-06-26 9:01:22’,‘2023-06-28 00:00:00’) #结束时间-开始时间小于48小时,结果为1
select timestampdiff(day,‘2023-06-26 9:01:22’,‘2023-06-28 09:01:21’) #结束时间-开始时间小于48小时,结果为1
select timestampdiff(day,‘2023-06-26 9:01:22’,‘2023-06-28 09:01:22’) #结束时间-开始时间等于48小时,结果为2

此处需要注意:两个函数开始时间与结束时间的位置是反的。

由此可见两者以天为单位的计算区别。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值