SQL優(yōu)化:合理使用臨時(shí)表
當(dāng)前位置:點(diǎn)晴教程→知識管理交流
→『 技術(shù)文檔交流 』
今天我們來講講臨時(shí)表的優(yōu)化技巧 臨時(shí)表,顧名思義就只是臨時(shí)使用的一張表,一種是本地臨時(shí)表,只能在當(dāng)前查詢頁面使用,新開查詢是不能使用它的,一種是全局臨時(shí)表,不管開多少查詢頁面均可使用。 本地臨時(shí)表 本地臨時(shí)表在表名前加#即可,我們先來看看本地臨時(shí)表的特性 我們新建一個(gè)查詢頁面,輸入如下代碼:
結(jié)果如下: 我們再新開一個(gè)頁面,重新輸入如下代碼:
結(jié)果如下: 證明本地臨時(shí)表只能在當(dāng)前頁面執(zhí)行。 全局臨時(shí)表 全局臨時(shí)表在表名前加##即可,打開任何一個(gè)查詢頁面都可以使用它。 重復(fù)上面的步驟:
結(jié)果和上面一樣: 我們再新開一個(gè)頁面:
結(jié)果還是一樣。證明全局臨時(shí)表所有查詢頁面均可以使用。 臨時(shí)表的優(yōu)化方法 介紹完臨時(shí)表,我們來說說如何用它來進(jìn)行優(yōu)化 臨時(shí)表的優(yōu)化一般使用再子查詢較多的情況下,也稱為嵌套查詢。我們寫如下子查詢:
(提示:代碼可以左右滑動(dòng)) 這是一個(gè)比較簡單的兩層嵌套子查詢,我們看一下執(zhí)行情況: 可以看到這里的邏輯讀取是比較高的。 我們用臨時(shí)表重新來看下執(zhí)行情況如何,我們將第一二層的查詢結(jié)果插入到#temp中,然后從臨時(shí)表中查詢結(jié)果。
執(zhí)行情況如下: 相比上一次的邏輯讀,成倍的減少了邏輯讀取次數(shù)。在對查詢的性能進(jìn)行調(diào)節(jié)時(shí),如果邏輯讀值下降,就表明查詢使用的服務(wù)器資源減少,查詢的性能有所提高。如果邏輯讀值增加,則表示調(diào)節(jié)措施降低了查詢的性能。在其他條件不變的情況下,一個(gè)查詢使用的邏輯讀越少,其效率就越高,查詢的速度就越快。 因此我們可以看出臨時(shí)表在比較復(fù)雜的嵌套查詢中是可以提高查詢效率的。 今天的課就講到這里,有不明白的同學(xué)可以在下方留言,我會一一回復(fù)。 閱讀原文:原文鏈接 該文章在 2025/6/23 12:58:23 編輯過 |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |