MySQL中日期、时间直接相减的坑

前言

在牛客网上写一道 SQL 题时,需要计算两个日期之间相隔的秒数,我在写的时候直接将两个日期进行相减,得出来的值却不是相差的秒数。

情景再现

我在 MySQL 中进行了测试,得出的结论是:如果日期类型直接相减,那么每分钟的间隔会被当成是 100 秒,而不是 60 秒。知道了结论之后,以后计算两个日期之间相差的秒数就再也不敢随意相减了。(图中描述有误,正确的应该是一、三行和中间一行)
在这里插入图片描述

解决方案

使用 TIME_TO_SEC 函数计算一个日期类型的时间戳,两个时间戳相减的结果就是两个时间相差的秒数了,还可以使用 TIMESTAMPDIFF 函数来直接得到两个时间的相差的秒、分、小时、天、月、年。

  1. 使用 TIME_TO_SEC 函数
    在这里插入图片描述
  2. 使用 TIMESTAMPDIFF 函数
    在这里插入图片描述
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值