您好,登錄后才能下訂單哦!
本篇內容主要講解“臨時表在SQL優化中的作用是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“臨時表在SQL優化中的作用是什么”吧!
今天我們來講講臨時表的優化技巧
臨時表,顧名思義就只是臨時使用的一張表,一種是本地臨時表,只能在當前查詢頁面使用,新開查詢是不能使用它的,一種是全局臨時表,不管開多少查詢頁面均可使用。
SQL Server 2017
本地臨時表在表名前加#即可,我們先來看看本地臨時表的特性
我們新建一個查詢頁面,輸入如下代碼:
SELECT TOP 10 * INTO #temp FROM sales.Temp_Salesorder; SELECT * FROM #temp;
結果如下:
我們再新開一個頁面,重新輸入如下代碼:
SELECT * FROM #temp;
結果如下:
證明本地臨時表只能在當前頁面執行。
全局臨時表在表名前加##即可,打開任何一個查詢頁面都可以使用它。
重復上面的步驟:
SELECT TOP 10 * INTO ##temp FROM sales.Temp_Salesorder SELECT * FROM ##temp;
結果和上面一樣:
我們再新開一個頁面:
SELECT * FROM ##temp;
結果還是一樣。證明全局臨時表所有查詢頁面均可以使用。
介紹完臨時表,我們來說說如何用它來進行優化
臨時表的優化一般使用再子查詢較多的情況下,也稱為嵌套查詢。我們寫如下子查詢:
SELECT * FROM sales.Temp_Salesorder WHERE SalesOrderDetailID IN (SELECT SalesOrderDetailID FROM sales.SalesOrderDetail WHERE UnitPrice IN (SELECT UnitPrice FROM sales.SalesOrderDetail WHERE UnitPrice>0) )
(提示:代碼可以左右滑動)
這是一個比較簡單的兩層嵌套子查詢,我們看一下執行情況:
可以看到這里的邏輯讀取是比較高的。
我們用臨時表重新來看下執行情況如何,我們將第一二層的查詢結果插入到#temp中,然后從臨時表中查詢結果。
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)
執行情況如下:
相比上一次的邏輯讀,成倍的減少了邏輯讀取次數。在對查詢的性能進行調節時,如果邏輯讀值下降,就表明查詢使用的服務器資源減少,查詢的性能有所提高。如果邏輯讀值增加,則表示調節措施降低了查詢的性能。在其他條件不變的情況下,一個查詢使用的邏輯讀越少,其效率就越高,查詢的速度就越快。
因此我們可以看出臨時表在比較復雜的嵌套查詢中是可以提高查詢效率的。
到此,相信大家對“臨時表在SQL優化中的作用是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。