SQLServer中的DATEADD怎么使用-创新互联

这篇文章主要讲解了“SQL Server中的DATEADD怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SQL Server中的DATEADD怎么使用”吧!

目前成都创新互联公司已为上1000+的企业提供了网站建设、域名、虚拟主机网站托管运营、企业网站设计、汕头网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

句法

与类似的功能一样,  DATEADD 可以对日期和时间进行算术运算。语法很简单:

DATEADD (datepart, number, date)

该  number 部分必须是整数,并且必须在日期部分的可接受值范围内。

该  datepart 部分必须是以下日期部分之一(我们在之前的   帖子中看到  过):

DATEPART缩略语
是的,yyyy
25美分硬币qq,q
mm,m
DAYOFYEARdy,y
dd,d
wk,ww
平日dw,w
小时HH
分钟mi,n
第二ss,s
毫秒女士
微秒MCS
纳秒NS

虽然  DATEADD 支持上表中所示的缩写,但我们应尽一切努力使用完整表达式来确保代码的清晰度。如果我们使用缩写,SQL Server不会运行得更快。

另请注意,虽然我们可以使用纳秒加或减  DATEADD,但DATETIME2 数据类型的最小粒度为  100纳秒,因此需要考虑舍入。

退货类型

DATEADD 将使用date 参数中使用的数据类型返回结果  。例如,如果我们使用以YYYYMMDD 格式表示日期的文字字符串  ,则返回类型将是一个  DATETIME 值,因为文字字符串被隐式转换为  DATETIME

SELECT DATEADD(DAY,1,'20181031')
- 返回DATETIME值'2018-11-01 00:00:00.000'

但是,如果我们使用  DATETIME2 输入值,结果将是一个  DATETIME2 值。

SELECT DATEADD(纳秒,100,CAST('20181031'  AS DATETIME2))
- 返回DATETIME2值'2018-10-31 00:00:00.0000001'

加减

我们之前看到过  DATEADD 可以用于加法    减法,这使得向后和向前计算值变得容易。我们假设我们需要计算100天前的时间点。如果我们以今天为出发点,它将如下所示:

DECLARE  @dt DATETIME2 = SYSUTCDATETIME();
SELECT  @dt  AS [TimeNow],DATEADD(DAY, - 100,@ dt)AS [TimeThen];

注意在部分中使用负号  number 。结果如下:

TimeNow: 2018-10-31 09:17:21.7866500
TimeThen: 2018-07-23 09:17:21.7866500

几个月的算术

关于这个功能的最后一个想法。在增加或减少月数时,请注意不包含31天的月份。例如,让我们在2018年2月底添加一个月:

SELECT DATEADD(MONTH,1,'20180228')
- 返回DATETIME值'20180328'

但是,如果我们在2018年1月底添加一个,两个或三个月,我们会看到不同的结果:

SELECT DATEADD(MONTH,1,'20180131');
- 返回DATETIME值'20180228'

SELECT DATEADD(MONTH,2,'20180131');
- 返回DATETIME值'20180331'

SELECT DATEADD(MONTH,3,'20180131');
- 返回DATETIME值'20180430'

DATEADD 是一个非常有用的系统函数在T-SQL中添加和减去日期和时间的值,我广泛使用。只要我们记住它围绕数据类型和数月长度的怪癖,它就会非常强大。

感谢各位的阅读,以上就是“SQL Server中的DATEADD怎么使用”的内容了,经过本文的学习后,相信大家对SQL Server中的DATEADD怎么使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!


新闻名称:SQLServer中的DATEADD怎么使用-创新互联
链接分享:http://scjbc.cn/article/ddssjg.html

其他资讯