sql server 游标循环插入数据

SQL事务与游标实战
本文详细介绍了一段SQL脚本的实现过程,该脚本使用事务和游标来处理数据库中特定用户的数据。通过声明变量、设置错误处理、定义事务、创建游标等步骤,实现了对未关联系统对象ID的用户进行数据插入操作。此过程展示了SQL中事务控制和游标使用的具体细节。

begin
  declare @temp varchar(50)
  declare @error int
  set @error = 0

  declare @sysObjectId int
  set @sysObjectId = 167
  declare @count int
  select @count=Count(UserId) from (select distinct UserID from HomeSort where UserID not in (select UserID from HomeSort where SysObjectID in (@sysObjectId))) as t
  print @count

  begin tran
  -- 声明游标为UserID
  declare HomeSort_cursor cursor
  for(select [UserID] from (select distinct UserID from HomeSort where UserID not in (select UserID from HomeSort where SysObjectID =@sysObjectId)) as t1)
  -- 打开游标
  open HomeSort_cursor
  -- 开始循环游标变量
  fetch next from HomeSort_cursor into @temp
  while @@FETCH_STATUS = 0 -- 返回被FETCH语句执行的最后游标的状态
    begin
      set @error = @error + @@ERROR
      insert into HomeSort (SysObjectID, UserID, SortNum) values (@sysObjectId, @temp, 10)
      fetch next from HomeSort_cursor into @temp -- 转到下一个游标
    end
  if @error = 0
    begin
      print '提交成功'
      commit tran -- 提交事务
    end
    else
    begin
      print '回滚'
      rollback tran -- 回滚事务
    end
    close HomeSort_cursor -- 关闭游标
    deallocate HomeSort_cursor --释放游标
end

转载于:https://www.cnblogs.com/zhoujiahong/p/9933461.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值