love33jing2012
浪仙
采纳率100%
2019-06-28 10:31

sql使用游标插入数据 为什么出现死循环?

5
已采纳

create table stu
(
id int,
names varchar(120)
)

insert into stu(id,names)
values (1,'wdl')

insert into stu(id,names)
values (2,'cyc')

insert into stu(id,names)
values (3,'zyz')

declare @id int
declare @names nvarchar(200)

declare myCursor cursor for

select id,names from stu
open myCursor
fetch next from myCursor into @id,@names

while @@FETCH_STATUS=0
begin
insert into dbo.stu values(@id+3,@names)
fetch next from myCursor into @id,@names
end
close myCursor
deallocate myCursor

select * from stu


  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

2条回答

  • chinarealone chinarealone 2年前

    确定不是特意写的死循环吗?一边先stu表插入新的记录,一边从stu表获取记录,fetch永远可以得到新记录,@@FETCH_STATUS=0永远为真,当然是死循环了。

    点赞 评论 复制链接分享
  • luojianjun2 Flying_with_you 2年前

    @@FETCH_STATUS fetch成功就返回0.那你这fetch成功while就能一直循环,没办法停止下来肯定死循环了。

    点赞 1 评论 复制链接分享

相关推荐