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

数据库 SQL Server
在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循环语句示例

责任编辑:段燃 来源: 互联网
相关推荐

2010-07-22 16:02:29

2011-03-29 13:22:07

SQL Server临时表表变量

2010-09-16 15:10:48

SQL Server表

2010-09-08 17:29:37

SQL表变量

2010-09-16 17:56:31

SQL server临

2010-09-16 15:03:10

SQL Server临

2010-07-23 13:42:11

SQL Server临

2010-07-26 13:56:38

SQL Server临

2010-10-19 14:45:01

SQL SERVER临

2011-09-02 14:45:43

Oracle临时表SQL Server临

2010-07-08 14:42:34

SQL Server临

2010-10-19 14:56:05

sql server临

2010-10-19 15:25:05

Sql Server临

2021-01-18 05:23:14

SQL 排序Server

2014-09-25 09:43:29

临时表表变量SQL

2010-07-22 15:56:04

SQL Server临

2010-11-12 13:27:13

动态sql

2010-05-19 09:01:14

MySQL临时表

2021-04-29 08:11:11

SQL优化作用

2010-09-02 16:28:03

SQL删除
点赞
收藏

51CTO技术栈公众号