首先,您应该绝对确定需要遍历每行-在我能想到的每种情况下,基于集合的操作都将更快地执行,并且通常将使用更简单的代码。根据您的数据,可能仅使用select语句就可以进行循环,如下所示:Declare @Id intWhile (Select Count(*) From ATable Where Processed = 0) > 0Begin Select Top 1 @Id = Id From ATable Where Processed = 0 --Do some processing here Update ATable Set Processed = 1 Where Id = @Id End另一种选择是使用临时表:Select *Into #TempFrom ATableDeclare @Id intWhile (Select Count(*) From #Temp) > 0Begin Select Top 1 @Id = Id From #Temp --Do some processing here Delete #Temp Where Id = @IdEnd您应该选择的选项实际上取决于数据的结构和数量。注意:如果您使用的是SQL Server,则最好使用以下服务:WHILE EXISTS(SELECT * FROM #Temp)使用COUNT将不得不触摸表中的每一行,EXISTS唯一需要触摸第一行。
这是我的方法:declare @RowNum int, @CustId nchar(5), @Name1 nchar(25)select @CustId=MAX(USERID) FROM UserIDs --start with the highest IDSelect @RowNum = Count(*) From UserIDs --get total number of recordsWHILE @RowNum > 0 --loop until no more recordsBEGIN select @Name1 = username1 from UserIDs where USERID= @CustID --get other info from that row print cast(@RowNum as char(12)) + ' ' + @CustId + ' ' + @Name1 --do whatever select top 1 @CustId=USERID from UserIDs where USERID < @CustID order by USERID desc--get the next one set @RowNum = @RowNum - 1 --decrease countEND没有游标,没有临时表,没有额外的列。像大多数主键一样,USERID列必须是唯一的整数。