为什么我写的带循环的存储过程却不执行循环呢?只执行一句就结束了

jellon_hero 2006-10-31 05:02:15
SET @i = 1;
WHILE (@i <= @@rowcount)
BEGIN
UPDATE @EXHI_INDUSTRY
SET [ex_id] = (SELECT TOP 1 [ex_id]
FROM [cnexpo_exhibition]
WHERE [ex_industry] = (SELECT [industry_code]
FROM @EXHI_INDUSTRY
WHERE [Row_ID] = @i)),
[ex_name] = (SELECT TOP 1 [ex_name]
FROM [cnexpo_exhibition]
WHERE [ex_industry] = (SELECT [industry_code]
FROM @EXHI_INDUSTRY
WHERE [Row_ID] = @i))
WHERE [ROW_ID] = @i

SET @i = @i + 1
IF @i > @@rowcount
BREAK
END

这种格式应该没有错误吧?谁能指点一下?
...全文
157 8 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
jellon_hero 2006-11-01
  • 打赏
  • 举报
回复
谢了,循环条件出了问题,@@rowcount,执行以次后返回1,不再是原来的值了
job_2006 2006-11-01
  • 打赏
  • 举报
回复
关注
uml6688 2006-10-31
  • 打赏
  • 举报
回复
UPDATE 可以优化
写成

UPDATE table set a.t=b.t,..
from xx a,kk b
where ...

hegang888888888 2006-10-31
  • 打赏
  • 举报
回复
@@rowcount,执行一次后返回1
hegang888888888 2006-10-31
  • 打赏
  • 举报
回复
@@rowcount,执行以次后返回1
jellon_hero 2006-10-31
  • 打赏
  • 举报
回复
我测出@i的值为2,意思就是@i从开始的1依次往下执行下去,而没有执行循环的过程,
这是什么原因啊?
jellon_hero 2006-10-31
  • 打赏
  • 举报
回复
我开始也没加IF @i > @@rowcount
    BREAK
这一句,后来节上的,我试试查看@i到底是多少哈,谢谢先
copico 2006-10-31
  • 打赏
  • 举报
回复
IF @i > @@rowcount
BREAK
这一句就不用要了
最后你print @i
看看你的i值是多少

62,243

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧