伍佰目录 短网址
  当前位置:海洋目录网 » 站长资讯 » 站长资讯 » 文章详细 订阅RssFeed

SQL优化小讲堂(三)——合理使用临时表

来源:本站原创 浏览:97次 时间:2022-08-07

SQL专栏

SQL基础知识汇总

SQL高级知识汇总

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

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


本地临时表

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

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

SELECT TOP 10 * INTO #tempFROM sales.Temp_Salesorder;SELECT * FROM #temp;

结果如下:

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

SELECT * FROM #temp;

结果如下:

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

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

重复上面的步骤:

SELECT TOP 10 * INTO ##tempFROM sales.Temp_SalesorderSELECT * FROM ##temp;

结果和上面一样:


我们再新开一个页面:

SELECT * FROM ##temp;

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

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

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

SELECT * FROM sales.Temp_SalesorderWHERE SalesOrderDetailID IN(SELECT SalesOrderDetailID FROM sales.SalesOrderDetailWHERE UnitPrice IN(SELECT UnitPrice FROM sales.SalesOrderDetail WHERE UnitPrice>0))

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

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

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

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

SELECT SalesOrderDetailID INTO #temp FROM sales.SalesOrderDetailWHERE UnitPrice IN (SELECT UnitPrice FROM sales.SalesOrderDetail WHERE UnitPrice>0)SELECT * FROM sales.Temp_SalesorderWHERE SalesOrderDetailID IN(SELECT SalesOrderDetailID FROM #temp)

执行情况如下:

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

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

今天的课就讲到这里,有不明白的同学可以在下方留言,我会一一回复。

  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net