table变量 VS  临时表

临时表:
Select CustomerID,CompanyName,ContactName INTO #MyTable FROM Customers
Select CustomerID,CompanyName,ContactName FROM #MyTable
Drop TABLE #MyTable

table变量:
DECLARE @MyTable table(CustomerID nchar(5),CompanyName nvarchar(40),ContactName nvarchar(30))
Insert INTO @MyTable(CustomerID,CompanyName,ContactName) Select CustomerID,CompanyName,ContactName FROM Customers
Select CustomerID,CompanyName,ContactName FROM @MyTable

上边两个T-SQL的结果是一样的,但在联机丛书中建议尽可能使用表变量而不使用临时表。table 变量有以下优点:

·table 变量的行为类似于局部变量,有明确定义的作用域。该作用域为声明该变量的函数、存储过程或批处理。
在其作用域内,table 变量可像常规表那样使用。该变量可应用于 Select、Insert、Update 和 Delete 语句中用到表或表的表达式的地方。但是,table 不能用在下列语句中:
Insert INTO table_variable EXEC 存储过程。
Select select_list INTO table_variable 语句。
在定义 table 变量的函数、存储过程或批处理结束时,自动清除 table 变量。

·在存储过程中使用表变量与使用临时表相比,减少了存储过程的重新编译量。

·涉及表变量的事务只在表变量更新期间存在。这样就减少了表变量对锁定和记录资源的需求。

注意:不支持在表变量之间进行赋值操作。另外,由于表变量作用域有限,并且不是持久数据库的一部分,因而不受事务回滚的影响。

上一篇: SQL语句union关键字使用
下一篇: C#生成彩色验证码
文章来自: 本站原创
引用通告: 查看所有引用 | 我要引用此文章
Tags:
最新日志:
评论: 0 | 引用: 0 | 查看次数: 3852
发表评论
登录后再发表评论!