偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

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

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

[[396741]]

本文轉(zhuǎn)載自微信公眾號(hào)「SQL數(shù)據(jù)庫(kù)開(kāi)發(fā)」,作者丶平凡世界 。轉(zhuǎn)載本文請(qǐng)聯(lián)系SQL數(shù)據(jù)庫(kù)開(kāi)發(fā)公眾號(hào)。

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

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

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

SQL Server 2017

1、本地臨時(shí)表

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

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

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

結(jié)果如下:

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

  1. SELECT * FROM #temp

結(jié)果如下:

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

2、全局臨時(shí)表

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

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

  1. SELECT TOP 10 * INTO ##temp 
  2. FROM sales.Temp_Salesorder 
  3. SELECT * FROM ##temp

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

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

  1. SELECT * FROM ##temp

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

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

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

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

  1. SELECT * FROM sales.Temp_Salesorder 
  2. WHERE SalesOrderDetailID IN  
  3. (SELECT SalesOrderDetailID FROM sales.SalesOrderDetail 
  4. WHERE UnitPrice IN 
  5. (SELECT UnitPrice FROM sales.SalesOrderDetail WHERE UnitPrice>0) 

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

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

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

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

  1. SELECT SalesOrderDetailID INTO #temp FROM sales.SalesOrderDetail 
  2. WHERE UnitPrice IN (SELECT UnitPrice FROM sales.SalesOrderDetail WHERE UnitPrice>0) 
  3.  
  4. SELECT * FROM sales.Temp_Salesorder 
  5. WHERE SalesOrderDetailID IN  
  6. (SELECT SalesOrderDetailID FROM #temp

執(zhí)行情況如下:

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

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

 

責(zé)任編輯:武曉燕 來(lái)源: SQL數(shù)據(jù)庫(kù)開(kāi)發(fā)
相關(guān)推薦

2009-03-18 10:56:29

生命周期全局臨時(shí)表SQL Server

2011-03-29 13:22:07

SQL Server臨時(shí)表表變量

2010-07-26 13:56:38

SQL Server臨

2010-05-19 09:01:14

MySQL臨時(shí)表

2010-09-08 16:03:57

SQL臨時(shí)表數(shù)據(jù)庫(kù)

2010-10-19 14:45:01

SQL SERVER臨

2013-09-26 14:11:23

SQL性能優(yōu)化

2010-09-16 17:56:31

SQL server臨

2010-09-16 15:03:10

SQL Server臨

2011-08-22 15:47:27

Oracle臨時(shí)表存儲(chǔ)過(guò)程

2021-01-18 05:23:14

SQL 排序Server

2011-09-02 14:45:43

Oracle臨時(shí)表SQL Server臨

2010-09-16 15:10:48

SQL Server表

2010-07-08 14:42:34

SQL Server臨

2010-10-19 15:25:05

Sql Server臨

2009-07-01 02:29:24

臨時(shí)表T-SQL

2010-10-19 15:31:40

sql server觸

2010-07-22 16:02:29

2010-09-01 11:46:01

DB2臨時(shí)表SQL

2010-07-01 14:46:10

SQL Server臨
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)