前言
在牛客网上写一道 SQL 题时,需要计算两个日期之间相隔的秒数,我在写的时候直接将两个日期进行相减,得出来的值却不是相差的秒数。
情景再现
我在 MySQL 中进行了测试,得出的结论是:如果日期类型直接相减,那么每分钟的间隔会被当成是 100 秒,而不是 60 秒。知道了结论之后,以后计算两个日期之间相差的秒数就再也不敢随意相减了。(图中描述有误,正确的应该是一、三行和中间一行)

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

- 使用 TIMESTAMPDIFF 函数

文章讲述了在牛客网编程时遇到的问题,即直接用日期类型相减会导致秒数计算错误。作者发现MySQL中,日期相减每分钟间隔被视为100秒。解决方法是使用TIME_TO_SEC函数或TIMESTAMPDIFF函数精确计算秒数差异。
2861

被折叠的 条评论
为什么被折叠?



