SQL中表变量是否必须替代临时表

http://database.51cto.com  2010-09-08 17:35  佚名  互联网   我要评论(0)
  • 摘要:在SQL数据库中,必须使用表变量来代替临时表吗?插入到表中的行数、从中保存查询的重新编译的次数、以及查询类型及其对性能的指数和统计信息的依赖性这三个因素将是决定其是否成立的重要因素。
  • 标签:SQL  表变量

SQL数据库中,必须使用表变量来代替临时表吗?答案取决于三个因素:插入到表中的行数、从中保存查询的重新编译的次数、以及查询类型及其对性能的指数和统计信息的依赖性。 

在某些情况下,可将一个具有临时表的存储过程拆分为多个较小的存储过程,以便在较小的单元上进行重新编译。

通常情况下,应尽量使用表变量,除非数据量非常大并且需要重复使用表。在这种情况下,可以在临时表上创建索引以提高查询性能。但是,各种方案可能互不相同。Microsoft 建议您做一个测试,来验证表变量对于特定的查询或存储过程是否比临时表更有效。

============================

declare @temp table 

    [id] int IDENTITY(1,1), 
    [Name] varchar(10) 

declare @tempId int,@tempName varchar(10)

insert into @temp values('a') 
insert into @temp values('b') 
insert into @temp values('c') 
insert into @temp values('d') 
insert into @temp values('e')

--select * from @temp

WHILE EXISTS(select [id] from @temp) 
begin 
SET ROWCOUNT 1 
select @tempId = [id],@tempName=[Name] from @temp 
SET ROWCOUNT 0 
delete from @temp where [id] = @tempId

print 'Name:----'+@tempName 
end 

【编辑推荐】

SQL中表变量的不足

详解SQL中循环结构的使用

SQL循环执行while控制

SQL中游标嵌套循环的示例

SQL循环语句示例

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值