天天看点

SQL语句获得时间差

在sql中计算时间差

DATEDIFF

返回跨两个指定日期的日期和时间边界数。

语法

​DATEDIFF ( datepart , startdate , enddate ) ​

参数

datepart

是规定了应在日期的哪一部分计算差额的参数。下表列出了 Microsoft? SQL Server? 识别的日期部分和缩写。

日期部分 缩写
year yy, yyyy
quarter qq, q
Month mm, m
dayofyear dy, y
Day dd, d
Week wk, ww
Hour hh
minute mi, n
second ss, s
millisecond ms

startdate

是计算的开始日期。startdate 是返回 datetime 或 smalldatetime

因为 smalldatetime 只精确到分钟,所以当用 smalldatetime

如果您只指定年份的最后两位数字,则小于或等于"两位数年份截止期"配置选项的值的最后两位数字的数字所在世纪与截止年所在世纪相同。大于该选项的值的最后两位数字的数字所在世纪为截止年所在世纪的前一个世纪。例如,如果 two digit year cutoff 为 2049(默认),则 49 被解释为 2049,2050 被解释为 1950。为避免模糊,请使用四位数的年份。

有关时间值指定的更多信息,请参见​​时间格式​​​。有关日期指定的更多信息,请参见 ​​datetime 和 smalldatetime​​。

enddate

是计算的终止日期。enddate 是返回 datetime 或 smalldatetime

返回类型

integer

注释

startdate 是从 enddate 减去。如果 startdate 比 enddate

示例
USE pubs
GO
SELECT DATEDIFF(day, pubdate, getdate()) AS no_of_days
FROM titles