3

我在将分钟转换为小数时遇到了一些问题,即使我已经查看了 SO 的其他回复。

select cast(datediff(minute, min(start_time), min(complete_time)) as decimal (10,10)) 
from TRACKED_OBJECT_HISTORY TOH1 
where TOH1.op_name = 'Assembly'

结果返回,但我总是得到像 2.00、4.00、5.00 这样的结果,而不是像 1.86、3.99、5.03 这样的数字。我猜它是事后转换(我也尝试了转换功能无济于事)。有什么想法吗?

4

1 回答 1

7

Datediff 返回一个整数,而不是浮点数或数字。

为了得到你想要的,也许你应该在几秒钟内完成差异然后划分:

select cast(datediff(second, min(start_time), min(complete_time))/60.0 as decimal (10,10))
from TRACKED_OBJECT_HISTORY TOH1 where TOH1.op_name = 'Assembly'
于 2012-08-10T01:24:09.830 回答