SQL Server:
DECLARE @Date1 DATETIME
SET @Date1 = '2012-26-12 12:00:05 AM'
DECLARE @Date2 DATETIME
SET @Date2 = '2012-28-12 12:00:00 AM'
SELECT @Date1, @Date2, DATEDIFF(DAY,@Date1,@Date2)
return 2VB.Net
DateDiff(DateInterval.Day,Convert.ToDateTime("26-12-2012 12:00:05 AM"),
Convert.ToDateTime("28-12-2012 12:00:00 AM"))
return 1为什么结果会有所不同?我的两点意见是,SQL Server的DateDiff只减去日期时间值(28 - 26)的日部分,而.Net DateDiff精确地减去两个日期时间值(秒或毫秒),并转换为等价的日值。
或者,这是因为操作系统的区域和语言设置?
提前感谢
发布于 2012-12-26 14:49:05
实际上,VB.NET表达式返回的是正确的值,因为hours的总数不等于48 .Hence,它返回1
在SQL Server中,DateDiff函数返回舍入值。
尝试将该值除以天中的总秒数,即86400.0
SELECT @Date1, @Date2, DATEDIFF(ss,@Date1,@Date2) /86400.0返回值将不是2,而是1.9999421
以秒为单位的2个日期之间的差值为172795,小于172800 (2天的总秒数).Hence如果不对结果进行舍入,则函数应仅返回1
发布于 2012-12-26 14:21:09
Day DateDiff向下舍入返回的数字。尝试返回小时数并除以24以获得天数
DateDiff(DateInterval.Hour,Convert.ToDateTime("26-12-2012 12:00:05 AM"),
Convert.ToDateTime("28-12-2012 12:00:00 AM"))/24https://stackoverflow.com/questions/14036532
复制相似问题