多种临时表效率的对比分析

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介: 多种临时表效率的对比分析老帅(20141107)平时在写存储过程的时候,经常会用到临时表,而临时表的用法到底有几种,哪种效率更好呢?我们来做个对比分析。
多种临时表效率的对比分析
老帅(20141107)
平时在写存储过程的时候,经常会用到临时表,而临时表的用法到底有几种,哪种效率更好呢?我们来做个对比分析。
实验数据:表a有400万条记录,只查询一个字段Title

1.  直接查询
--开启时间分析
SET STATISTICS TIME ON 
GO
--查询
SELECT Title FROM a 
--结果
SQL Server 执行时间:占用时间 = 22013 毫秒。

2.变量表
--开启时间分析
SET STATISTICS TIME ON 
GO
--插入
DECLARE @tmpA TABLE
(
 Title VARCHAR(200)
)
INSERT INTO @tmpA
SELECT Title FROM a
--查询
SELECT * FROM @tmpA
--结果
SQL Server 执行时间: 占用时间 = 22913 毫秒。

3.临时表
--开启时间分析
SET STATISTICS TIME ON 
GO
--插入
CREATE TABLE #tmpA
(
 Title VARCHAR(200)
)
INSERT INTO #tmpA
SELECT Title FROM a
--查询
SELECT * FROM #tmpA
--结果
SQL Server 执行时间: 占用时间 = 22743 毫秒。

4.不创建临时表,直接插入到临时表
--开启时间分析
SET STATISTICS TIME ON 
GO
--插入
SELECT * INTO #tmpA  
FROM
(SELECT Title FROM a) AS b
--查询
SELECT * FROM #tmpA
--结果
SQL Server 执行时间:  占用时间 = 22671 毫秒。

5.使用WITH AS临时表
--开启时间分析
SET STATISTICS TIME ON;
--插入
WITH tmpA AS
(
SELECT Title FROM a
)
--查询
SELECT * FROM tmpA
--结果
SQL Server 执行时间: 占用时间 = 22188 毫秒。

通过以上的分析,很容易看出哪种方法效率更高了。 在存储过程中尽量使用临时表来存储临时数据,不要使用变量表。

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
8月前
|
缓存 关系型数据库 MySQL
MySQL 查询优化:提速查询效率的13大秘籍(索引设计、查询优化、缓存策略、子查询优化以及定期表分析和优化)(中)
MySQL 查询优化:提速查询效率的13大秘籍(索引设计、查询优化、缓存策略、子查询优化以及定期表分析和优化)(中)
1281 0
|
JavaScript 前端开发 API
【项目数据优化三】长列表数据优化
【项目数据优化三】长列表数据优化
138 0
|
SQL 存储 关系型数据库
如何通过索引让 SQL 查询效率最大化
如何通过索引让 SQL 查询效率最大化
106 0
如何通过索引让 SQL 查询效率最大化
|
SQL 关系型数据库 MySQL
【MySQL优化】一分钟带你了解双表联查优化
【MySQL优化】一分钟带你了解双表联查优化
299 0
【MySQL优化】一分钟带你了解双表联查优化
|
SQL 测试技术
临时表在SQL优化中的作用
今天我们来讲讲临时表的优化技巧 临时表,顾名思义就只是临时使用的一张表,一种是本地临时表,只能在当前查询页面使用,新开查询是不能使用它的,一种是全局临时表,不管开多少查询页面均可使用。
临时表在SQL优化中的作用
|
SQL 存储 索引
|
SQL 关系型数据库 数据库
大量使用临时表带来的问题,替代方案,以及如何擦屁股
以前有使用Greenplum的朋友遇到元表膨胀的问题,总结了原因写了一篇文章如下。建议先阅读这篇文档,再阅读本文,里面有些原理我在本文就不讲了。http://blog.163.com/digoal@126/blog/static/1638770402014616113353555 近日,又有使用P
6780 0
|
存储 算法 关系型数据库
「mysql优化专题」视图应用竟然还可以这么优化?不得不收藏(8)
当一个大型系统在建立时,会发现,数据库虽然可以存储海量的数据,可是一旦数据关系复杂,比如学生表(学号、姓名、年龄),学生成绩表(学号、科目、成绩),如需要姓名、科目、成绩组成关系,这样的情况我们选择创建一个新表是非常浪费资源的动作,为此,视图诞生了! 一、视图概述: (1)什么是视图? 视图是基于 SQL 语句的结果集的可视化的表。