开发者社区 问答 正文

MySQL:如何以秒为单位获取两个时间戳之间的差异?mysql

有没有一种方法可以在MySQL中进行查询,以秒为单位提供两个时间戳之间的差异,还是需要在PHP中进行?如果是这样,我将如何去做?

展开
收起
保持可爱mmm 2020-05-16 22:12:34 389 分享 版权
1 条回答
写回答
取消 提交回答
  • 您可以使用TIMEDIFF()和TIME_TO_SEC()函数,如下所示:

    SELECT TIME_TO_SEC(TIMEDIFF('2010-08-20 12:01:00', '2010-08-20 12:00:00')) diff; +------+ | diff | +------+ | 60 | +------+ 1 row in set (0.00 sec) 您还可以使用其他答案中建议的@AmberUNIX_TIMESTAMP()函数:

    SELECT UNIX_TIMESTAMP('2010-08-20 12:01:00') - UNIX_TIMESTAMP('2010-08-20 12:00:00') diff; +------+ | diff | +------+ | 60 | +------+ 1 row in set (0.00 sec) 如果您使用的是TIMESTAMP数据类型,我猜想UNIX_TIMESTAMP()解决方案会稍微快一点,因为TIMESTAMP值已经存储为整数,代表自纪元(Source)以来的秒数。引用文档:

    在列UNIX_TIMESTAMP()上使用时TIMESTAMP,该函数直接返回内部时间戳记值,而没有隐式的“字符串到Unix时间戳记”转换。

    请注意,TIMEDIFF() 返回数据类型为TIME。TIME值的范围可以从“ -838:59:59”到“ 838:59:59”(大约34.96天)来源:stack overflow

    2020-05-16 22:28:07
    赞同 展开评论