3 回答

TA貢獻(xiàn)1911條經(jīng)驗(yàn) 獲得超7個(gè)贊
首先,您應(yīng)該絕對(duì)確定需要遍歷每行-在我能想到的每種情況下,基于集合的操作都將更快地執(zhí)行,并且通常將使用更簡(jiǎn)單的代碼。
根據(jù)您的數(shù)據(jù),可能僅使用select語(yǔ)句就可以進(jìn)行循環(huán),如下所示:
Declare @Id int
While (Select Count(*) From ATable Where Processed = 0) > 0
Begin
Select Top 1 @Id = Id From ATable Where Processed = 0
--Do some processing here
Update ATable Set Processed = 1 Where Id = @Id
End
另一種選擇是使用臨時(shí)表:
Select *
Into #Temp
From ATable
Declare @Id int
While (Select Count(*) From #Temp) > 0
Begin
Select Top 1 @Id = Id From #Temp
--Do some processing here
Delete #Temp Where Id = @Id
End
您應(yīng)該選擇的選項(xiàng)實(shí)際上取決于數(shù)據(jù)的結(jié)構(gòu)和數(shù)量。
注意:如果您使用的是SQL Server,則最好使用以下服務(wù):
WHILE EXISTS(SELECT * FROM #Temp)
使用COUNT將不得不觸摸表中的每一行,EXISTS唯一需要觸摸第一行。

TA貢獻(xiàn)1853條經(jīng)驗(yàn) 獲得超18個(gè)贊
簡(jiǎn)要說明一下,如果您使用的是SQL Server(2008及更高版本),則示例包含:
While (Select Count(*) From #Temp) > 0
最好搭配
While EXISTS(SELECT * From #Temp)
Count必須觸摸表中的每一行,EXISTS唯一需要觸摸的第一行。

TA貢獻(xiàn)1829條經(jīng)驗(yàn) 獲得超13個(gè)贊
這是我的方法:
declare @RowNum int, @CustId nchar(5), @Name1 nchar(25)
select @CustId=MAX(USERID) FROM UserIDs --start with the highest ID
Select @RowNum = Count(*) From UserIDs --get total number of records
WHILE @RowNum > 0 --loop until no more records
BEGIN
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 count
END
沒有游標(biāo),沒有臨時(shí)表,沒有額外的列。像大多數(shù)主鍵一樣,USERID列必須是唯一的整數(shù)。
- 3 回答
- 0 關(guān)注
- 700 瀏覽
添加回答
舉報(bào)