第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

有沒有一種方法可以在不使用游標(biāo)的情況下遍歷TSQL中的表變量?

有沒有一種方法可以在不使用游標(biāo)的情況下遍歷TSQL中的表變量?

紫衣仙女 2019-12-07 16:19:16
假設(shè)我有以下簡(jiǎn)單的表變量:declare @databases table(    DatabaseID    int,    Name        varchar(15),       Server      varchar(15))-- insert a bunch rows into @databases如果要遍歷行,是否聲明和使用游標(biāo)是我唯一的選擇?還有另一種方法嗎?
查看完整描述

3 回答

?
Smart貓小萌

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唯一需要觸摸第一行。


查看完整回答
反對(duì) 回復(fù) 2019-12-07
?
慕容森

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唯一需要觸摸的第一行。


查看完整回答
反對(duì) 回復(fù) 2019-12-07
?
烙印99

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ù)。


查看完整回答
反對(duì) 回復(fù) 2019-12-07
  • 3 回答
  • 0 關(guān)注
  • 700 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)