浪仙 2019-06-28 10:31 采纳率: 100%
浏览 512
已采纳

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

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 2019-07-01 09:15
    关注

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥15 请问Lammps做复合材料拉伸模拟,应力应变曲线问题
  • ¥30 python代码,帮调试
  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊