不错呦!smile@林凯西,确保“准备文件”中的几个文件都有安装,S...您好,看了您这篇帖子觉得很有帮助。但是有个问题想请...我的修改过了怎么还被恶意注册呢 @jjjjiiii 用PJ快9年了,主要是A...PJ3啊,貌似很少有人用PJ了,现在不是WP就是z...@332347365,我当时接入时错误码没有-10...楼主,ChkValue值应为-103是什么意思呢?...大哥 你最近能看到我发的信息,请跟我联系,我有个制...
table变量 VS 临时表
编辑:dnawo 日期:2008-08-31
临时表:
table变量:
上边两个T-SQL的结果是一样的,但在联机丛书中建议尽可能使用表变量而不使用临时表。table 变量有以下优点:
·table 变量的行为类似于局部变量,有明确定义的作用域。该作用域为声明该变量的函数、存储过程或批处理。
在其作用域内,table 变量可像常规表那样使用。该变量可应用于 Select、Insert、Update 和 Delete 语句中用到表或表的表达式的地方。但是,table 不能用在下列语句中:
Insert INTO table_variable EXEC 存储过程。
Select select_list INTO table_variable 语句。
在定义 table 变量的函数、存储过程或批处理结束时,自动清除 table 变量。
·在存储过程中使用表变量与使用临时表相比,减少了存储过程的重新编译量。
·涉及表变量的事务只在表变量更新期间存在。这样就减少了表变量对锁定和记录资源的需求。
注意:不支持在表变量之间进行赋值操作。另外,由于表变量作用域有限,并且不是持久数据库的一部分,因而不受事务回滚的影响。
复制内容到剪贴板
程序代码

Select CustomerID,CompanyName,ContactName INTO #MyTable FROM Customers
Select CustomerID,CompanyName,ContactName FROM #MyTable
Drop TABLE #MyTable
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
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 变量。
·在存储过程中使用表变量与使用临时表相比,减少了存储过程的重新编译量。
·涉及表变量的事务只在表变量更新期间存在。这样就减少了表变量对锁定和记录资源的需求。
注意:不支持在表变量之间进行赋值操作。另外,由于表变量作用域有限,并且不是持久数据库的一部分,因而不受事务回滚的影响。
评论: 0 | 引用: 0 | 查看次数: 3852
发表评论
请登录后再发表评论!