成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

臨時表在SQL優化中的作用

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

[[396741]]

本文轉載自微信公眾號「SQL數據庫開發」,作者丶平凡世界 。轉載本文請聯系SQL數據庫開發公眾號。

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

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

0、測試環境

SQL Server 2017

1、本地臨時表

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

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

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

結果如下:

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

  1. SELECT * FROM #temp

結果如下:

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

2、全局臨時表

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

重復上面的步驟:

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

結果和上面一樣:

我們再新開一個頁面:

  1. SELECT * FROM ##temp

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

3、臨時表的優化方法

介紹完臨時表,我們來說說如何用它來進行優化

臨時表的優化一般使用再子查詢較多的情況下,也稱為嵌套查詢。我們寫如下子查詢:

  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) 

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

這是一個比較簡單的兩層嵌套子查詢,我們看一下執行情況:

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

我們用臨時表重新來看下執行情況如何,我們將第一二層的查詢結果插入到#temp中,然后從臨時表中查詢結果。

  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

執行情況如下:

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

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

 

責任編輯:武曉燕 來源: SQL數據庫開發
相關推薦

2009-03-18 10:56:29

生命周期全局臨時表SQL Server

2011-03-29 13:22:07

SQL Server臨時表表變量

2010-07-26 13:56:38

SQL Server臨

2010-05-19 09:01:14

MySQL臨時表

2010-09-08 16:03:57

SQL臨時表數據庫

2010-10-19 14:45:01

SQL SERVER臨

2013-09-26 14:11:23

SQL性能優化

2010-09-16 17:56:31

SQL server臨

2010-09-16 15:03:10

SQL Server臨

2011-08-22 15:47:27

Oracle臨時表存儲過程

2021-01-18 05:23:14

SQL 排序Server

2011-09-02 14:45:43

Oracle臨時表SQL Server臨

2010-07-08 14:42:34

SQL Server臨

2010-10-19 15:25:05

Sql Server臨

2010-09-16 15:10:48

SQL Server表

2009-07-01 02:29:24

臨時表T-SQL

2010-10-19 15:31:40

sql server觸

2010-07-22 16:02:29

2010-09-01 11:46:01

DB2臨時表SQL

2010-07-01 14:46:10

SQL Server臨
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 天天操天天干天天曰 | 干一干操一操 | 2一3sex性hd | 九一视频在线播放 | 日韩国产中文字幕 | 日韩成年人视频在线 | 开操网| 国产小视频在线 | 国产传媒在线观看 | av毛片| 国产精品国产三级国产aⅴ原创 | 成人国产精品久久久 | 欧美日韩视频 | 久久综合影院 | 亚洲一区二区三区免费视频 | 中文字幕亚洲视频 | 动漫www.被爆羞羞av44 | 免费欧美 | 365夜爽爽欧美性午夜免费视频 | 国产精品美女久久久久久免费 | 日韩a | 欧美视频一区 | 精品国产一级 | 久久国产传媒 | 麻豆国产一区二区三区四区 | 欧美日韩高清在线观看 | 国产伦精品一区二区 | 成人精品一区二区 | 电影午夜精品一区二区三区 | 北条麻妃99精品青青久久主播 | 天天躁日日躁aaaa视频 | 91精品国产91久久久久久最新 | 中文字幕不卡在线观看 | 中文二区 | 少妇一级淫片免费放播放 | 亚洲免费视频网站 | av在线视 | 男女视频在线观看网站 | 激情五月综合网 | 蜜桃在线视频 | 欧美久久精品一级黑人c片 91免费在线视频 |