临时表在SQL优化中的作用

运维 数据库运维
临时表,顾名思义就只是临时使用的一张表,一种是本地临时表,只能在当前查询页面使用,新开查询是不能使用它的,一种是全局临时表,不管开多少查询页面均可使用。

[[396741]]

本文转载自微信公众号「SQL数据库开发」,作者丶平凡世界 。转载本文请联系SQL数据库开发公众号。

今天我们来讲讲临时表的优化技巧

临时表,顾名思义就只是临时使用的一张表,一种是本地临时表,只能在当前查询页面使用,新开查询是不能使用它的,一种是全局临时表,不管开多少查询页面均可使用。

0、测试环境

SQL Server 2017

1、本地临时表

本地临时表在表名前加#即可,我们先来看看本地临时表的特性

我们新建一个查询页面,输入如下代码:

  1. SELECT TOP 10 * INTO #temp 
  2. FROM sales.Temp_Salesorder; 
  3. SELECT * FROM #temp

结果如下:

我们再新开一个页面,重新输入如下代码:

  1. SELECT * FROM #temp

结果如下:

证明本地临时表只能在当前页面执行。

2、全局临时表

全局临时表在表名前加##即可,打开任何一个查询页面都可以使用它。

重复上面的步骤:

  1. SELECT TOP 10 * INTO ##temp 
  2. FROM sales.Temp_Salesorder 
  3. SELECT * FROM ##temp

结果和上面一样:

我们再新开一个页面:

  1. SELECT * FROM ##temp

结果还是一样。证明全局临时表所有查询页面均可以使用。

3、临时表的优化方法

介绍完临时表,我们来说说如何用它来进行优化

临时表的优化一般使用再子查询较多的情况下,也称为嵌套查询。我们写如下子查询:

  1. SELECT * FROM sales.Temp_Salesorder 
  2. WHERE SalesOrderDetailID IN  
  3. (SELECT SalesOrderDetailID FROM sales.SalesOrderDetail 
  4. WHERE UnitPrice IN 
  5. (SELECT UnitPrice FROM sales.SalesOrderDetail WHERE UnitPrice>0) 

(提示:代码可以左右滑动)

这是一个比较简单的两层嵌套子查询,我们看一下执行情况:

可以看到这里的逻辑读取是比较高的。

我们用临时表重新来看下执行情况如何,我们将第一二层的查询结果插入到#temp中,然后从临时表中查询结果。

  1. SELECT SalesOrderDetailID INTO #temp FROM sales.SalesOrderDetail 
  2. WHERE UnitPrice IN (SELECT UnitPrice FROM sales.SalesOrderDetail WHERE UnitPrice>0) 
  3.  
  4. SELECT * FROM sales.Temp_Salesorder 
  5. WHERE SalesOrderDetailID IN  
  6. (SELECT SalesOrderDetailID FROM #temp

执行情况如下:

相比上一次的逻辑读,成倍的减少了逻辑读取次数。在对查询的性能进行调节时,如果逻辑读值下降,就表明查询使用的服务器资源减少,查询的性能有所提高。如果逻辑读值增加,则表示调节措施降低了查询的性能。在其他条件不变的情况下,一个查询使用的逻辑读越少,其效率就越高,查询的速度就越快。

因此我们可以看出临时表在比较复杂的嵌套查询中是可以提高查询效率的。

 

责任编辑:武晓燕 来源: SQL数据库开发
相关推荐

2009-03-18 10:56:29

生命周期全局临时表SQL Server

2011-03-29 13:22:07

SQL Server临时表表变量

2010-07-26 13:56:38

SQL Server临

2010-05-19 09:01:14

MySQL临时表

2010-09-08 16:03:57

SQL临时表数据库

2010-10-19 14:45:01

SQL SERVER临

2013-09-26 14:11:23

SQL性能优化

2010-09-16 15:03:10

SQL Server临

2010-09-16 17:56:31

SQL server临

2021-01-18 05:23:14

SQL 排序Server

2011-09-02 14:45:43

Oracle临时表SQL Server临

2010-09-16 15:10:48

SQL Server表

2011-08-22 15:47:27

Oracle临时表存储过程

2010-07-08 14:42:34

SQL Server临

2010-10-19 15:25:05

Sql Server临

2009-07-01 02:29:24

临时表T-SQL

2010-10-19 15:31:40

sql server触

2010-09-01 11:46:01

DB2临时表SQL

2010-07-22 16:02:29

2010-07-01 14:46:10

SQL Server临
点赞
收藏

51CTO技术栈公众号