首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQL Server DateDiff与.Net DateDiff

SQL Server DateDiff与.Net DateDiff
EN

Stack Overflow用户
提问于 2012-12-26 13:58:28
回答 2查看 1.8K关注 0票数 2

SQL Server:

代码语言:javascript
复制
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 2

VB.Net

代码语言:javascript
复制
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精确地减去两个日期时间值(秒或毫秒),并转换为等价的日值。

或者,这是因为操作系统的区域和语言设置?

提前感谢

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-12-26 14:49:05

实际上,VB.NET表达式返回的是正确的值,因为hours的总数不等于48 .Hence,它返回1

在SQL Server中,DateDiff函数返回舍入值。

尝试将该值除以天中的总秒数,即86400.0

代码语言:javascript
复制
SELECT @Date1, @Date2, DATEDIFF(ss,@Date1,@Date2) /86400.0

返回值将不是2,而是1.9999421

以秒为单位的2个日期之间的差值为172795,小于172800 (2天的总秒数).Hence如果不对结果进行舍入,则函数应仅返回1

票数 4
EN

Stack Overflow用户

发布于 2012-12-26 14:21:09

Day DateDiff向下舍入返回的数字。尝试返回小时数并除以24以获得天数

代码语言:javascript
复制
DateDiff(DateInterval.Hour,Convert.ToDateTime("26-12-2012 12:00:05 AM"), 
Convert.ToDateTime("28-12-2012 12:00:00 AM"))/24
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14036532

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档