首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >DATEADD函数SQL

DATEADD函数SQL
EN

Stack Overflow用户
提问于 2018-10-25 18:30:55
回答 3查看 263关注 0票数 0

我想选择从1st jan 201731 dec 2018的数据。

我有一个查询,其中我使用了BETWEEN DATEADD(year,-1,GETDATE()) AND DATEADD(year,1,GETDATE()),但我只能从october 2017jan 2019获取数据。我怎样才能做到这一点呢?任何建议都非常感谢。

EN

回答 3

Stack Overflow用户

发布于 2018-10-25 18:32:22

一种方法是使用datediff()

代码语言:javascript
复制
where datediff(year, datecol, getdate()) <= 1

一种更明显的方法是进行明确的日期比较:

代码语言:javascript
复制
where datecol >= datefromparts(year(getdate()) - 1, 1, 1) and
      datecol < datefromparts(year(getdate()) + 1, 1, 1)
票数 1
EN

Stack Overflow用户

发布于 2018-10-25 18:35:34

您将需要使用以下代码:

代码语言:javascript
复制
between DATEADD(year,-1,DATEADD(yy, DATEDIFF(yy, 0, GETDATE()), 0))
and     DATEADD(yy, DATEDIFF(yy, 0, GETDATE()) + 1, -1)

它说明了日期在前一年的第一个日期和本年度的最后一个日期之间的位置,例如。1st jan 2017 till 31 dec 2018

你得到了错误的日期,因为getdate()是当前日期,所以当你得到-1年时,它是从今天开始的,应该是25 October 2018,然后说-1 = 25 October 2017。与另一个日期添加相同。

票数 0
EN

Stack Overflow用户

发布于 2018-10-25 18:42:45

你可以像下面这样简单地写它,

代码语言:javascript
复制
select * from table_name WHERE (date_column BETWEEN '2017-01-01' AND '2019-01-01')

或者,您也可以使用datepart来选择特定年份

代码语言:javascript
复制
select * from table_name where datepart(YYYY,date_column) >=2017 and datepart(YYYY,date_column) <=2019
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52987141

复制
相关文章

相似问题

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