gpt4 book ai didi

sql - 需要根据开始日期输入获取数据

转载 作者:行者123 更新时间:2023-12-04 06:05:19 25 4
gpt4 key购买 nike

我正在尝试根据我的开始日期输入检索数据。如果用户选择开始日期为 11-27-2011,结束日期为 12/04/2011,那么我的数据集返回的日期将是整个 11 月。如果他们选择 10/01/2011 的开始日期,那么我的数据集将返回从 1 月 1 日到当前日期的数据。

我已经设法使第二个/第三个语句正常工作,但是当我尝试添加过滤器以从 1 月 1 日开始检索数据时,它出错了(查询中的第一个 IF 语句)。第一个 IF 语句检查@BeginningDate 是否小于前一个月。如果是 THEN,它应该检索年份数据,否则它会从那里继续。这是我对日期的查询:

Declare @startdate  datetime
Declare @enddate datetime
Declare @BeginningDate datetime

set @BeginningDate = '12-01-2011'

IF Month(@BeginningDate) < (Month(GETDATE())-1)
BEGIN
set @startdate = DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)
set @enddate = dateadd(day, datediff(day, 0, getdate()), 0)
END

IF Month(@BeginningDate) = (Month(GETDATE())-1)
BEGIN
set @startdate = dateadd (mm,-1,DATEADD(dd,-(DAY(DATEADD(mm,1,convert(varchar(10),getdate(),111)))-1),DATEADD(mm,0,convert(varchar(10),getdate(),111))))--BEGINNING OF PRIOR MONTH
set @enddate =DATEADD(dd,-1,DATEADD(mm, DATEDIFF(m,0,convert(varchar(10),getdate(),111)),0))--END OF PRIOR MONTH
END

ELSE
IF Month(@BeginningDate) = (Month(GETDATE())
BEGIN
set @startdate = dateadd(month, datediff(month, 0, dateadd(day, datediff(day, 1, getdate()), 0)), 0)--BEGINNING OF CURRENT MONTH
set @enddate = dateadd(day, datediff(day, 0, getdate()), 0)--THROUGH CURRENT MONTH (TODAY)
END

正如我所说,我可以设法使查询与两个语句一起使用,但是当我添加第一个 IF 然后解析它时,我收到以下消息:

error message

第 15 行是最后一个 ELSE 语句中的“BEGIN”。我是否试图做太多的 IF/ELSE 语句?就这么多日期参数以及在 IF/ELSE 中使用它们而言,我以前从未这样做过。

提前致谢!

最佳答案

看起来像这条线 IF Month(@BeginningDate) = (Month(GETDATE())缺少一个 )

改成这个
IF Month(@BeginningDate) = (Month(GETDATE()))看看它现在是否有效

关于sql - 需要根据开始日期输入获取数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8435192/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com