为了账号安全,请及时绑定邮箱和手机立即绑定

有没有一种方法可以在不使用游标的情况下遍历TSQL中的表变量?

有没有一种方法可以在不使用游标的情况下遍历TSQL中的表变量?

紫衣仙女 2019-12-07 16:19:16
假设我有以下简单的表变量:declare @databases table(    DatabaseID    int,    Name        varchar(15),       Server      varchar(15))-- insert a bunch rows into @databases如果要遍历行,是否声明和使用游标是我唯一的选择?还有另一种方法吗?
查看完整描述

3 回答

?
Smart猫小萌

TA贡献1911条经验 获得超7个赞


首先,您应该绝对确定需要遍历每行-在我能想到的每种情况下,基于集合的操作都将更快地执行,并且通常将使用更简单的代码。


根据您的数据,可能仅使用select语句就可以进行循环,如下所示:


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

另一种选择是使用临时表:


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

您应该选择的选项实际上取决于数据的结构和数量。


注意:如果您使用的是SQL Server,则最好使用以下服务:


WHILE EXISTS(SELECT * FROM #Temp)

使用COUNT将不得不触摸表中的每一行,EXISTS唯一需要触摸第一行。


查看完整回答
反对 回复 2019-12-07
?
慕容森

TA贡献1853条经验 获得超18个赞

简要说明一下,如果您使用的是SQL Server(2008及更高版本),则示例包含:


While (Select Count(*) From #Temp) > 0

最好搭配


While EXISTS(SELECT * From #Temp)

Count必须触摸表中的每一行,EXISTS唯一需要触摸的第一行。


查看完整回答
反对 回复 2019-12-07
?
烙印99

TA贡献1829条经验 获得超13个赞

这是我的方法:


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

没有游标,没有临时表,没有额外的列。像大多数主键一样,USERID列必须是唯一的整数。


查看完整回答
反对 回复 2019-12-07
  • 3 回答
  • 0 关注
  • 611 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信