SQL存储过程中 错误156:在关键字‘set’附近有语法错误

SQL2000的存储过程如下,检查时老是出现错误156:在关键字‘set’附近有语法错误,请高手指导。CREATEPROCEDURE[test]asDeclare@nin... SQL2000的存储过程如下,检查时老是出现错误156:在关键字‘set’附近有语法错误,请高手指导。
CREATE PROCEDURE [test]
as
Declare @n int
Declare @ct datetime
set @n=-30
while @n<0
begin
set @ct=DATEADD(DAY,@n, GETDATE())
INSERT INTO AI
SELECT AVG (f1) AS f1, AVG (f2) AS f2, AVG (f3) AS f3, @ct AS dt
FROM demo
WHERE (YEAR(dt)=YEAR(@ct) AND (Month(dt)=MONTH(@ct) AND (Day(dt)=DAY (@ct)
set @n=@n+1
end
go
CREATE PROCEDURE [test]
as
Declare @n int
Declare @ct datetime
set @n=-30
while @n<0
begin
set @ct=DATEADD(DAY,@n, GETDATE())
INSERT INTO AI
SELECT AVG (f1) AS f1, AVG (f2) AS f2, AVG (f3) AS f3, @ct AS dt
FROM demo
WHERE (YEAR(dt)=YEAR(@ct))AND (Month(dt)=MONTH(@ct)) AND (Day(dt)=DAY (@ct))
set @n=@n+1
end
go
展开
 我来答
HJ_3000
2016-07-06 · TA获得超过563个赞
知道小有建树答主
回答量:1264
采纳率:78%
帮助的人:56.7万
展开全部
WHERE 部分括号混乱,不对称啊,弄不清楚就每个条件一行,一目了然。
百度网友024827e
2016-07-06 · TA获得超过1657个赞
知道大有可为答主
回答量:1117
采纳率:93%
帮助的人:352万
展开全部
CREATE PROCEDURE [test]
as
Declare @n int
Declare @ct datetime
set @n=-30
while @n<0
begin
set @ct=DATEADD(DAY,@n, GETDATE())
INSERT INTO AI
SELECT AVG (f1) AS f1, AVG (f2) AS f2, AVG (f3) AS f3, @ct AS dt
FROM demo
WHERE YEAR(dt)=YEAR(@ct) AND Month(dt)=MONTH(@ct) AND Day(dt)=DAY (@ct)
set @n=@n+1
end
go
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式