溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

臨時(shí)表在SQL優(yōu)化中的作用是什么

發(fā)布時(shí)間:2021-07-02 17:47:31 來(lái)源:億速云 閱讀:282 作者:chen 欄目:數(shù)據(jù)庫(kù)

本篇內(nèi)容主要講解“臨時(shí)表在SQL優(yōu)化中的作用是什么”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“臨時(shí)表在SQL優(yōu)化中的作用是什么”吧!

今天我們來(lái)講講臨時(shí)表的優(yōu)化技巧

臨時(shí)表,顧名思義就只是臨時(shí)使用的一張表,一種是本地臨時(shí)表,只能在當(dāng)前查詢(xún)頁(yè)面使用,新開(kāi)查詢(xún)是不能使用它的,一種是全局臨時(shí)表,不管開(kāi)多少查詢(xún)頁(yè)面均可使用。

0、測(cè)試環(huán)境

SQL Server 2017

1、本地臨時(shí)表

本地臨時(shí)表在表名前加#即可,我們先來(lái)看看本地臨時(shí)表的特性

我們新建一個(gè)查詢(xún)頁(yè)面,輸入如下代碼:

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

結(jié)果如下:

臨時(shí)表在SQL優(yōu)化中的作用是什么

我們?cè)傩麻_(kāi)一個(gè)頁(yè)面,重新輸入如下代碼:

SELECT * FROM #temp;

結(jié)果如下:

臨時(shí)表在SQL優(yōu)化中的作用是什么

證明本地臨時(shí)表只能在當(dāng)前頁(yè)面執(zhí)行。

2、全局臨時(shí)表

全局臨時(shí)表在表名前加##即可,打開(kāi)任何一個(gè)查詢(xún)頁(yè)面都可以使用它。

重復(fù)上面的步驟:

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

結(jié)果和上面一樣:

臨時(shí)表在SQL優(yōu)化中的作用是什么

我們?cè)傩麻_(kāi)一個(gè)頁(yè)面:

SELECT * FROM ##temp;

結(jié)果還是一樣。證明全局臨時(shí)表所有查詢(xún)頁(yè)面均可以使用。

3、臨時(shí)表的優(yōu)化方法

介紹完臨時(shí)表,我們來(lái)說(shuō)說(shuō)如何用它來(lái)進(jìn)行優(yōu)化

臨時(shí)表的優(yōu)化一般使用再子查詢(xún)較多的情況下,也稱(chēng)為嵌套查詢(xún)。我們寫(xiě)如下子查詢(xún):

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

(提示:代碼可以左右滑動(dòng))

這是一個(gè)比較簡(jiǎn)單的兩層嵌套子查詢(xún),我們看一下執(zhí)行情況:

臨時(shí)表在SQL優(yōu)化中的作用是什么

可以看到這里的邏輯讀取是比較高的。

我們用臨時(shí)表重新來(lái)看下執(zhí)行情況如何,我們將第一二層的查詢(xún)結(jié)果插入到#temp中,然后從臨時(shí)表中查詢(xún)結(jié)果。

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

執(zhí)行情況如下:

臨時(shí)表在SQL優(yōu)化中的作用是什么

臨時(shí)表在SQL優(yōu)化中的作用是什么

相比上一次的邏輯讀,成倍的減少了邏輯讀取次數(shù)。在對(duì)查詢(xún)的性能進(jìn)行調(diào)節(jié)時(shí),如果邏輯讀值下降,就表明查詢(xún)使用的服務(wù)器資源減少,查詢(xún)的性能有所提高。如果邏輯讀值增加,則表示調(diào)節(jié)措施降低了查詢(xún)的性能。在其他條件不變的情況下,一個(gè)查詢(xún)使用的邏輯讀越少,其效率就越高,查詢(xún)的速度就越快。

因此我們可以看出臨時(shí)表在比較復(fù)雜的嵌套查詢(xún)中是可以提高查詢(xún)效率的。

到此,相信大家對(duì)“臨時(shí)表在SQL優(yōu)化中的作用是什么”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢(xún),關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

sql
AI