首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >RedGate SQL提示-游标片段错误

RedGate SQL提示-游标片段错误
EN

Database Administration用户
提问于 2016-05-18 21:09:47
回答 1查看 216关注 0票数 2

使用RedGate的SQL提示符&热爱它。但是,我今天第一次使用了"curff“片段(”快速转发只读游标“),它生成了以下TSQL (我已将其填入以使其成为一个具体示例):

代码语言:javascript
复制
DECLARE @variable INT
DECLARE Curse CURSOR FAST_FORWARD READ_ONLY FOR
    SELECT ID FROM #TempTable

OPEN Curse
FETCH NEXT FROM Curse INTO @variable

WHILE @@FETCH_STATUS = 0
BEGIN
    FETCH NEXT FROM Curse INTO @variable  --This seems wrong...

    PRINT ('Hello, I am # ' + CAST(@variable AS VARCHAR(10)))
END

CLOSE Curse
DEALLOCATE Curse

内部FETCH NEXT (在WHILE循环中)的位置不正确吗?它应该在循环的末尾,或者至少在需要使用变量的查询(查询)之后,不是吗?

EN

回答 1

Database Administration用户

发布于 2016-05-18 21:20:10

是的,这是错误的。内部FETCH NEXT应该位于循环的末尾。上述守则将产生以下结果:

代码语言:javascript
复制
Hello, I am # 2
Hello, I am # 3
Hello, I am # 4
Hello, I am # 5
Hello, I am # 5

纠正问题,并将FETCH NEXT放在循环的末尾,将得到正确和预期的输出:

代码语言:javascript
复制
Hello, I am # 1
Hello, I am # 2
Hello, I am # 3
Hello, I am # 4
Hello, I am # 5

现在把这个提交给RedGate..。

票数 1
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/138937

复制
相关文章

相似问题

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