SQL 游标cursor

示例如下:

Create proc updateline
as
begin
  IF OBJECT_ID('tempdb..#tmp1') IS NOT NULL       
        BEGIN
            TRUNCATE TABLE #tmp1
            DROP TABLE #tmp1
        END
declare @Count int--总数
declare @i int--计数
set @i=1
select Row_Number()over(order by T0.Code)as Id,Code into  #tmp1 from (
select distinct Code  from ArticleAdd)T0
select @Count=Count(*) from #tmp1
while @i<=@Count
begin
declare ReduceQuantityoCursor cursor    --声明一个游标,读取MRP01表中数据循环扣减生产计划,生产订单,采购申请,采购订单,库存
for 
 select Row_Number()over(order by Code)as Id,Code,U_ACode from ArticleAdd where code=(select Code from #tmp1 where Id=@i)
open ReduceQuantityoCursor    --打开
declare @Code varchar(20)--Article编码
declare @U_ACode varchar(20)--Article项目编码
declare @Id varchar(20)--lineid
fetch next from ReduceQuantityoCursor into @Id,@Code,@U_ACode
while @@fetch_status=0    --循环读取 
begin--1
update ArticleAdd set Lineid=@Id where Code=@Code and U_ACode=@U_ACode
 fetch next from ReduceQuantityoCursor into @Id,@Code,@U_ACode
end--1
close ReduceQuantityoCursor        --关闭
deallocate ReduceQuantityoCursor    --删除
set @i=@i+1
end 
end

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值