我正在寻找能够获得时间的功能,并将其舍入到下一个/前一个小时/半小时/四分之一/分钟。

有帮助吗?

解决方案

尝试此功能

CREATE FUNCTION [dbo].[RoundTime] (@Time datetime, @RoundTo float)
RETURNS datetime
AS
BEGIN
   DECLARE @RoundedTime smalldatetime
   DECLARE @Multiplier float

   SET @Multiplier= 24.0/@RoundTo

   SET @RoundedTime= ROUND(CAST(CAST(CONVERT(varchar,@Time,121) AS datetime) AS float) * @Multiplier,0)/@Multiplier

   RETURN @RoundedTime
END



select dbo.roundtime('13:15',0.5)

第一个参数是圆形的时间,第二个参数将基于您的列表(0.5个半小时,1个小时,......)

其他提示

非常感谢。我在线使用它来回合15分钟

convert(smalldatetime,ROUND(cast(TDatalog.Time as float) * (24/.25),0)/(24/.25)) AS RoundedTime
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top