关于SQL while 循环嵌套 外部循环数据无法进入内部循环

下面一般是,作为SQL新手第一次写循环嵌套的办法,但是大家会发现一个问题,那就是变量@i总是不能进入第二个循环。

declare @i int ,@j int, @k int
set @i =
set @k =
set @j = 1 --注意 set @j=1 的位置, @j 是内部循环变量的初始变量。
while @i <=
begin
while @j <=
begin
set @k = @k +
set @j = @j +
end
set @i=@i+
end

那么解决问题的办法如下:

declare @i int ,@j int, @k int
set @i =
set @k=
while @i <=
begin
set @j =1 --@j位置的调整,将其调整到第一循环的begin开的内部。
while @j <=
begin
set @k =@k +
set @j =@j +
exec(@sql)
end
set @i=@i+
end

大家可以发现两端代码的不同之处,就是因为将 set @j=1 的位置进行了调整。

事实上,解决SQL,while 嵌套循环外部循环变量不能进入内部循环的解决办法就是 将内部循环变量的初始变量设置要放在外部循环的begin内部

---------------------------------------------------华丽丽的分割线----------------------------------------------------------

最后,介绍下自己,网名:一也

上一篇:解决win10“cmd自动弹出一闪而过”问题的方法


下一篇:面向企业级的开源WebGIS解决方案--MapGuide(对比分析)