1. 表变量
变
量都以@或@@为前缀,表变量是变量的一种,另外一种变量被称为标量(可以理解为标准变量,就是标准数据类型的变量,例如整型int或者日期型DateTime)。
以@前缀的表变量是本地的,因此只有在当前用户会话中才可以访问,而
@@前缀的表变量是全局的,通常都是系统变量,比如说 @@error代表最近的一个T-SQL语句的报错号。当然因为表变量首先是个变量,因此它只能在一个Batch中生存,也就是我们所说的边界,超出了这个边界,表变量也就消亡了。
表变量存放在内存中,正是因为这一点所有用户访问表变量的时候SQL Server是
不需要生成日志。同时变量是不需要考虑其他会话访问的问题,因此也
不需要锁机制,对于非常繁忙的系统来说,避免锁的使用可以减少一部分系统负载。
表变量另外还有一个限制就是
不能创建索引,当然
也不存在统计数据的问题,因此在用户访问表变量的时候也就不存在执行计划选择的问题了(也就是以为着编译阶段后就没有优化阶段了),这一特性有的时候是件好事,而有些时候却会造成一些麻烦。
2. 临时表
临时对象都以#或##为前缀,临时表是临时对象的一种,还有例如临时存储过程、临时函数之类的临时对象,
临时对象都存储在tempdb中。
以# 前缀的临时表为本地的,因此只有在当前用户会话中才可以访问,而
##前缀的临时表是全局的,因此所有用户会话都可以访问。
临时表以会话为边界,只要创建临时表的会话没有结束,临时表就会持续存在,当然用户在会话中可以通过DROP TABLE命令提前销毁临时表。
我们前面说过临时表存储在tempdb中,因此临时表的访问是有可能造成物理IO的,当然在
修改时也需要生成日志来确保一致性,同时
锁机制也是不可缺少的。
跟表变量另外一个显著区别就是
临时表可以创建索引,也可以定义统计数据,因此SQL Server在处理访问临时表的语句时需要考虑执行计划优化的问题。
3. 表变量 vs. 临时表
| 表变量 | 临时表 |
数据集的存储位置 | 内存 | 磁盘 |
是否需要日志 | 否 | 是 |
是否可以创建索引 | 否 | 是 |
是否可以使用统计数据 | 否 | 是 |
是否可以在多会话中访问 | 否 | 是 |
是否需要锁机制 | 否 | 是 |
对于
较小的临时计算用数据集推荐使用表变量。如果数据集比较大,如果在代码中用于临时计算,同时这种临时使用永远都是简单的全数据集扫描而不需要考虑什么优化,比如说没有分组或分组很少的聚合(比如说COUNT、SUM、AVERAGE、MAX等),也可以考虑使用表变量。使用表变量另外一个考虑因素是应用环境的内存压力,如果代码的运行实例很多,就要特别注意内存变量对内存的消耗。
一般对于
大的数据集我们推荐使用临时表,同时创建索引,或者通过SQL Server的统计数据(Statisitcs)自动创建和维护功能来提供访问SQL语句的优化。如果需要在多个用户会话间交换数据,当然临时表就是唯一的选择了。需要提及的是,由于临时表存放在tempdb中,因此要注意tempdb的调优。
补充:
1.表变量(如局部变量)具有明确定义的范围,在该范围结束时会自动清除这些表变量
而临时表需要手动的Drop。
2.与临时表相比,
表变量导致存储过程的重新编译更少;任何一个使用
临时表的存储过程都不会被预编译,然而使用
表变量的存储过程的执行计划可以预先静态的编译。预编译一个脚本的主要好处在于加快了执行的速度。这个好处对于长的存储过程更加显著,因为对它来说重新编译代价太高。
3.表变量仅存在于那些变量能存在的相同范围内。和临时表相反,它们在内部存储过程和exec(string)语句里是不可见的。
表变量不能在 INSERT EXEC 或 SELECT INTO 语句中使用。
4.
涉及表变量的事务仅维持表变量上更新的持续时间。因此,使用表变量时,需要锁定和记录资源的情况更少。因为表变量具有有限的范围并且不是持久性数据库的一部分,所以事务回滚并不影响它们
分享到:
相关推荐
资源名称:SQLServer中临时表与表变量的区别内容简介: 本文档主要讲述的是SQLServer中临时表与表变量的区别;希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看。资源截图: 资源太大,传百度网盘了,...
sqlserver 循环临时表插入数据到另一张表 -- 声明变量 DECLARE @SupCode as varchar(100), @ProdCode as varchar(50), @PackLayer as varchar(50), @CodeStatus as varchar(50), @ProductId as varchar(50), @...
在SQL Server中,临时表和表变量是两种用于暂存数据的结构,它们在数据库操作中扮演着重要的角色。理解它们的区别有助于优化存储过程和提高性能。 临时表类似于永久表,但它们存在于Tempdb系统数据库中,仅在创建它...
### SQL Server 中临时表与表变量的区别 #### 一、临时表 临时表与常规的永久表非常相似,主要区别在于其创建位置和生命周期。在SQL Server中,临时表是在`tempdb`数据库中创建的,这意味着它们仅在这个特定会话...
SQL Server的临时表是数据库操作中非常实用的工具,它们用于存储临时数据,尤其是在复杂的查询...在实际应用中,根据数据量、生命周期和可见性需求,明智地选择临时表或表变量,可以显著提高SQL Server应用程序的性能。
SQL Server的临时表是数据库管理中非常实用的工具,它们被用于存储临时数据,供当前会话或多个会话在特定范围内使用。临时表有两种类型:本地临时表(以单个井号`#`开头)和全局临时表(以两个井号`##`开头)。 1. ...
SQL Server中的临时表是数据库操作中非常实用的工具,尤其在处理临时数据集时。临时表分为两种类型:局部临时表(以单个井号 `#` 开头)和全局临时表(以双井号 `##` 开头)。下面将详细介绍这两种临时表的特性和...
在SQL Server中,临时表是一种用于存储临时数据的结构,它们在特定的会话或所有会话中(根据类型)存在,并在不再需要时自动删除。临时表分为两种类型:本地临时表(以单个井号`#`开头)和全局临时表(以双井号`##`...
与本地临时表不同,全局临时表在整个SQL Server实例中对所有会话可见。但是,它们的生命周期更为复杂,只有当创建它们的会话结束并且没有其他会话再引用它们时,全局临时表才会被自动删除。 临时表的一个常见用途是...
在SQL Server中,遍历和更新大量数据时,通常有两种主要方法:游标和使用临时表。本篇文章将重点探讨如何通过创建临时表来遍历并更新数据,以避免使用游标带来的性能损耗和复杂性。 首先,游标虽然直观,但其缺点...
在SQL Server中,表变量和临时表都是用来存储数据的临时结构,但它们在使用上存在显著的区别。本文将详细探讨这两个概念。 首先,我们来看看表变量。表变量是在SQL Server 2000中引入的新特性,它允许在批处理语句...
临时表与表变量是SQL Server中的两个相似概念,但它们之间有显著的区别。表变量的作用范围仅限于当前批处理或存储过程,不支持索引,而临时表可以创建索引,更适合处理大量数据和复杂的查询场景。 在优化查询性能...
表变量在SQL Server中是一种临时存储数据的结构,它与临时表相似但作用范围更小,仅限于当前批处理或存储过程。以下是一个使用表变量的例子: ```sql DECLARE @temp TABLE (id INT IDENTITY(1, 1), Name VARCHAR(10...
首先,我们创建了一个名为`#result`的临时表,包含三列:`Class`(类别)、`CallDate`(日期)和`CallCount`(计数)。接着,通过`INSERT INTO`语句向该表中插入了一些示例数据。 ### 二、动态SQL构建交叉表查询 ...
为了应对这些问题,SQL SERVER引入了表变量这种特殊的数据类型,它以其独特的性能和应用方式,在数据库编程中发挥了重要作用。 表变量是一种不写入磁盘的数据类型,它的执行速度非常快,而且在使用完毕后不需要进行...
5. **命名限制**:本地临时表的名称长度不能超过116个字符,因为SQL Server会在内部添加数字后缀以区分不同用户的表。 6. **存储位置**:所有的临时表都存储在tempdb系统数据库中。 7. **并发问题**:在多用户环境...
表变量可以看作是一种轻量级的临时表,它允许我们在存储过程中存储一组数据。这种方法更为安全且性能更好,因为它避免了SQL注入的风险,并且可以利用索引来优化查询。 ```sql CREATE PROCEDURE usp/DeleteByIds (@...