48

我已经忙了几个小时了,但我无法让它工作。

SQL

SELECT DATEDIFF(end_time, start_time) as `difference` FROM timeattendance WHERE timeattendance_id = '1484'

start_time =   2012-01-01   12:00:00
end_time =     2012-01-02   13:00:00

时差为 25(小时)。但我得到的输出是 1(天)。

如何获得 25 小时作为输出?

4

4 回答 4

115

使用TIMESTAMPDIFF怎么样?

SELECT TIMESTAMPDIFF(HOUR, start_time, end_time) 
           as `difference` FROM timeattendance WHERE timeattendance_id = '1484'
于 2012-07-20T13:07:27.803 回答
17

您最好使用 TIMEDIFF 而不是 DATEDIFF,因为 DATEDIFF 在比较之前会将所有时间转换为日期。执行 TIMEDIFF 后,您可以使用 HOUR 函数获取小时数。

SELECT HOUR(TIMEDIFF(end_time, start_time)) as `difference`;
于 2012-07-20T13:09:46.930 回答
5

您可以使用 TIMEDIFF 和 HOUR 函数来提取小时。

SELECT HOUR(TIMEDIFF(end_time, start_time)) as `difference` FROM timeattendance WHERE timeattendance_id = '1484'

http://dev.mysql.com/doc/refman/5.5/en/date-and-time-functions.html#function_timediff
http://dev.mysql.com/doc/refman/5.5/en/date-and -time-functions.html#function_hour

于 2012-07-20T13:11:23.450 回答
5

如 MySQL参考中所述,DATEDIFF只需要几天的时间。

如果两个日期都在 1970 年之后,您可以减去时间戳:

SELECT ( UNIX_TIMESTAMP("2012-01-02 13:00:00") - 
         UNIX_TIMESTAMP("2012-01-01 12:00:00") ) / 3600 ...

或者:

SELECT TIMEDIFF ( "2012-01-02 13:00:00", "2012-01-01 12:00:00") / 3600 ... 
于 2012-07-20T13:07:34.653 回答