日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

sql 临时表_原创 | SQL优化之合理使用临时表

發布時間:2024/1/23 数据库 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 sql 临时表_原创 | SQL优化之合理使用临时表 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

看海景大圖的推文嗎?將我們設為星標即可~

SQL專欄

SQL基礎知識匯總

SQL高級知識匯總

今天我們來講講臨時表的優化技巧

臨時表,顧名思義就只是臨時使用的一張表,一種是本地臨時表,只能在當前查詢頁面使用,新開查詢是不能使用它的,一種是全局臨時表,不管開多少查詢頁面均可使用。

1、本地臨時表

本地臨時表在表名前加#即可,我們先來看看本地臨時表的特性

我們新建一個查詢頁面,輸入如下代碼:

SELECT TOP 10 * INTO #temp
FROM sales.Temp_Salesorder;
SELECT * FROM #temp;結果如下:

我們再新開一個頁面,重新輸入如下代碼:

SELECT * FROM #temp;

結果如下:

證明本地臨時表只能在當前頁面執行。

2、全局臨時表

全局臨時表在表名前加##即可,打開任何一個查詢頁面都可以使用它。

重復上面的步驟:

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

結果和上面一樣:

我們再新開一個頁面:

SELECT * FROM ##temp;

結果還是一樣。證明全局臨時表所有查詢頁面均可以使用。

3、臨時表的優化方法

介紹完臨時表,我們來說說如何用它來進行優化臨時表的優化一般使用再子查詢較多的情況下,也稱為嵌套查詢。我們寫如下子查詢: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)執行情況如下:

相比上一次的邏輯讀,成倍的減少了邏輯讀取次數。在對查詢的性能進行調節時,如果邏輯讀值下降,就表明查詢使用的服務器資源減少,查詢的性能有所提高。如果邏輯讀值增加,則表示調節措施降低了查詢的性能。在其他條件不變的情況下,一個查詢使用的邏輯讀越少,其效率就越高,查詢的速度就越快。因此我們可以看出臨時表在比較復雜的嵌套查詢中是可以提高查詢效率的。今天的課就講到這里,有不明白的同學可以在下方留言,我會一一回復。——End——

關注SQL數據庫開發公眾號,在后臺回復關鍵字:資料領取,可以獲取一份精心整理的技術干貨。

推薦閱讀

  • 只因接了一個電話,程序員被騙 30 萬!

  • Linux環境下安裝MySQL數據庫示例教程

  • 原創 |?除了會排序,你對ORDER BY的用法可能一無所知!

點擊「」了解SQL訓練營

總結

以上是生活随笔為你收集整理的sql 临时表_原创 | SQL优化之合理使用临时表的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。