sql server中的循环遍历

sql server中的循环遍历

1.普通循环(while)

有点类似python代码的写法

 select djlsh,GSKH,PXH from BGZLLRB where DjLsh=8806 order by PXH

先从数据库里取一组数据
循环前的数据

declare @a int  
set @a=1
while @a<5
begin
	--处理数据
	update BGZLLRB set PXH=pxh+1 where  DjLsh=8806 
	set @a = @a +1
end

一共循环了四次,每次加一, 结果如下
循环后的结果

2 游标循环

有点类似python的迭代器,一条一条的取出数据处理

用上面循环后的数据,进行下面的循环

DECLARE @pxh int,@djlsh int,@gskh varchar(50)

declare order_cursor cursor  --定义游标
for (select djlsh,GSKH,PXH from BGZLLRB where DjLsh=8806)  --为游标赋值一个数据集
	open order_cursor			--打开游标
    fetch next from order_cursor into @djlsh,@GSKH,@PXH --开始循环游标变量(从数据集中拿出第一条数据)
    while @@FETCH_STATUS = 0     --返回被 FETCH语句执行的最后游标的状态 (固定写法)
	begin
	    update BGZLLRB set PXH=pxh-4 where  DjLsh=@djlsh and GSKH=@gskh
		fetch next from order_cursor into  @djlsh,@GSKH,@PXH --转到下一个游标(取下条数据集)
	end
	close order_cursor      -- 关闭游标
    deallocate order_cursor   -- 释放游标

游标循环后 的结果如下
在这里插入图片描述

3.游标循环 (事务)

跟游标循环差不多,无非就是多加了事务
还是用上面游标循环后的数据去处理

DECLARE @pxh int,@djlsh int,@gskh varchar(50),@error int

set @error =0
BEGIN TRAN --申明事务
declare order_cursor cursor
for (select djlsh,GSKH,PXH from BGZLLRB where DjLsh=8806)
	open order_cursor

    fetch next from order_cursor into @djlsh,@GSKH,@PXH
    while @@FETCH_STATUS = 0
	begin
	    update BGZLLRB set PXH=pxh-1 where  DjLsh=8806 and GSKH=@gskh
		set @error=@error+@@error--记录每次运行sql后是否正确,数值为0正确
		print(@@error)	--如果有错,可以看出哪条记录出错
		fetch next from order_cursor into  @djlsh,@GSKH,@PXH
	end
	close order_cursor  
    deallocate order_cursor
IF @error=0
BEGIN
	commit tran--提交
end
ELSE
BEGIN
	ROLLBACK TRAN--回滚
END

游标循环 (事务) 后 结果如下:
在这里插入图片描述

事务的好处是: 处理多条数据或者是多条sql去处理数据的时候,保证你的所有操作的一致性,要么一起错,要么一起处理完。当然如果你处理数据,处理错了,并且提交了,更新到数据库里了,也可以进行事务回滚,代码就不是我这样写了(要更复杂,我也不会)。

  • 6
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL Server,可以使用游标(cursor)来遍历临时表。 首先,我们需要创建一个临时表,并向其插入数据。可以使用以下语句来创建和插入数据: ```sql CREATE TABLE #TempTable ( ID INT, Name VARCHAR(50) ) INSERT INTO #TempTable(ID, Name) VALUES (1, 'John'), (2, 'Mike'), (3, 'Sarah') ``` 接下来,可以使用游标来遍历临时表。游标是一个类似指针的数据结构,可以逐行访问结果集。 ```sql DECLARE @ID INT DECLARE @Name VARCHAR(50) DECLARE TempCursor CURSOR FOR SELECT ID, Name FROM #TempTable OPEN TempCursor FETCH NEXT FROM TempCursor INTO @ID, @Name WHILE @@FETCH_STATUS = 0 BEGIN -- 在这里可以对每一行数据进行处理 PRINT 'ID: ' + CONVERT(VARCHAR(10), @ID) + ', Name: ' + @Name FETCH NEXT FROM TempCursor INTO @ID, @Name END CLOSE TempCursor DEALLOCATE TempCursor ``` 上述代码,我们声明了两个变量`@ID`和`@Name`来存储临时表的ID和Name列的值。然后,声明了一个游标`TempCursor`,并将临时表的数据集合赋给游标。接着,我们打开游标,并使用`FETCH NEXT`语句将第一行数据读取到变量。 在while循环,我们可以对每一行数据进行处理。在这里,我们使用`PRINT`语句将ID和Name的值打印出来,你可以在这里进行其他的处理操作。 最后,我们关闭游标并释放它所占用的资源。 需要注意的是,在使用游标遍历临时表时,一定要记得关闭和释放游标,以避免资源泄漏和性能问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值