亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

SQL Server 2016 查詢存儲性能優化小結

2024-08-31 01:03:38
字體:
來源:轉載
供稿:網友
SQL Server 2016已經發布了有半年多,相信還有很多小伙伴還沒有開始使用,今天我們來談談SQL Server 2016 查詢存儲性能優化,希望大家能夠喜歡
 

作為一個DBA,排除SQL Server問題是我們的職責之一,每個月都有很多人給我們帶來各種不能解釋卻要解決的性能問題。

我就多次聽到,以前的SQL Server的性能問題都還好且在正常范圍內,但現在一切已經改變,SQL Server開始糟糕, 瘋狂的事情不能解釋。在這個情況下我介入,分析下整個SQL Server的安裝,最后用一些神奇的調查方法找出性能問題的根源。

但很多時候問題的根源是一樣的:所謂的計劃回歸(Plan Regression),即特定查詢的執行計劃已經改變。昨天SQL Server已經緩存了在計劃緩存里緩存了一個好的執行計劃,今天就生成、緩存最后重用了一個糟糕的執行計劃——不斷重復。

進入SQL Server 2016后,我就變得有點多余了,以為微軟引進了查詢存儲(Query Store)。這是這個版本最熱門的功能!查詢存儲幫助你很容易找出你的性能問題是不是計劃回歸造成的。如果你找到了計劃回歸,這很容易強制一個特定計劃不使用計劃向導。聽起來很有意思?讓我們通過一個特定的場景,向你展示下在SQL Server 2016里,如何使用查詢存儲來找出并最終修正計劃回歸。

查詢存儲(Query Store)——我的對手

在SQL Server 2016里,在你使用查詢存儲功能前,你要對這個數據庫啟用它。這是通過ALTER DATABASE語句實現,如你所見的下列代碼:

CREATE DATABASE QueryStoreDemoGOUSE QueryStoreDemoGO-- Enable the Query Store for our databaseALTER DATABASE QueryStoreDemoSET QUERY_STORE = ONGO-- Configure the Query StoreALTER DATABASE QueryStoreDemo SET QUERY_STORE( OPERATION_MODE = READ_WRITE,  CLEANUP_POLICY = (STALE_QUERY_THRESHOLD_DAYS = 367),  DATA_FLUSH_INTERVAL_SECONDS = 900,  INTERVAL_LENGTH_MINUTES = 1,  MAX_STORAGE_SIZE_MB = 100,  QUERY_CAPTURE_MODE = ALL,  SIZE_BASED_CLEANUP_MODE = OFF)GO

 

在線幫助為你提供了各個選項的詳細信息。接下來我創建一個簡單的表,創建一個非聚集索引,最后插入80000條記錄。

 

-- Create a new tableCREATE TABLE Customers( CustomerID INT NOT NULL PRIMARY KEY CLUSTERED, CustomerName CHAR(10) NOT NULL, CustomerAddress CHAR(10) NOT NULL, Comments CHAR(5) NOT NULL, Value INT NOT NULL)GO-- Create a supporting new Non-Clustered Index.CREATE UNIQUE NONCLUSTERED INDEX idx_Test ON Customers(Value)GO-- Insert 80000 recordsDECLARE @i INT = 1WHILE (@i <= 80000)BEGIN INSERT INTO Customers VALUES (  @i,  CAST(@i AS CHAR(10)),  CAST(@i AS CHAR(10)),  CAST(@i AS CHAR(5)),  @i )  SET @i += 1ENDGO

為了訪問我們的表,我額創建了一個簡單的存儲過程,傳入value值作為過濾謂語。

 

-- Create a simple stored procedure to retrieve the dataCREATE PROCEDURE RetrieveCustomers( @Value INT)ASBEGIN SELECT * FROM Customers WHERE Value < @ValueENDGO

現在我用80000的參數值來執行存儲過程。

-- Execute the stored procedure. -- This generates an execution plan with a Key Lookup (Clustered). EXEC RetrieveCustomers 80000 GO

 

現在當你查看實際的執行計劃時,你會看到查詢優化器已經選擇了有419個邏輯讀的聚集索引掃描運算符。SQL Server并沒有使用非聚集索引,因為這樣沒有意義,由于臨界點。這個查詢結果并沒有選擇性。

SQL Server 2016 查詢存儲性能優化小結

現在假設SQL Server發生了些事情(例如重啟,故障轉移),SQL Server忽略已經緩存的計劃,這里我通過執行DBCC FREEPROCCACHE從計劃緩存里抹掉每個緩存的計劃來模擬SQL Server重啟(不要在生產環境里使用?。?/p>

 -- Get rid of the cached execution plan... DBCC FREEPROCCACHE GO

 

現在有人再次調用你的存儲過程,這次輸入參數值是1。這次執行計劃不一樣,因為現在在執行計劃里你會有書簽查找。SQL Server估計行數是1,在非聚集索引里沒有找到任何行。因此與非聚集索引查找結合的書簽查找才有意義,因為這個查詢是有選擇性的。

SQL Server 2016 查詢存儲性能優化小結

現在我再執行用80000參數值的查詢。

-- Execute the stored procedureEXEC RetrieveCustomers 1GO-- Execute the stored procedure again-- This introduces now a plan regression, because now we get a Clustered Index Scan-- instead of the Key Lookup (Clustered).EXEC RetrieveCustomers 80000GO

 

當你再次看STATISTICS IO的輸出,你會看到這個查詢現在產生了160139個邏輯讀——剛才的查詢只有419個邏輯讀。這個時候DBA的手機就會響起,性能問題。但今天我們要不同的方式解決——使用剛才啟用的查詢存儲。

當你再次看實際的執行計劃,在你面前你會看到有一個計劃回歸,因為SQL Server剛重用了書簽查找的的計劃緩存。剛才你有聚集索引掃描運算符的執行計劃。這是SQL Server里參數嗅探的副作用。

讓我們通過查詢存儲來詳細了解這個問題。在SSMS里的對象資源管理器里,SQL Server 2016提供了一個新的結點叫查詢存儲,這里你會看到一些報表。

SQL Server 2016 查詢存儲性能優化小結

【前幾個資源使用查詢】向你展示了最昂貴的查詢,基于你選擇的維度。這里切換到【邏輯讀取次數】。

SQL Server 2016 查詢存儲性能優化小結

這里在你面前有一些查詢。最昂貴的查詢生成了近500000個邏輯讀。這是我們的初始語句。這已經是第一個WOW效果的的查詢存儲:SQL Server重啟后,查詢存儲的數據還是存在的!第2個是你存儲過程里的SELECT語句。在查詢存儲里每個捕獲的查詢都有一個標示號——這里是7。最后當你看報告的右邊,你會看這個查詢的不同執行計劃。

SQL Server 2016 查詢存儲性能優化小結

如你所見,查詢存儲捕獲了2個不同的執行計劃,一個ID是7,一個ID是8。當你點擊計劃ID時,SQL Server會在報表的最下面為你顯示估計的執行計劃。

SQL Server 2016 查詢存儲性能優化小結

計劃8是聚集索引掃描,計劃7是書簽查找。如你所見,使用查詢存儲分析計劃回歸非常簡單。但你現在還沒結束。你現在可以對指定的查詢強制執行計劃。 現在你知道包含聚集索引掃描的執行計劃有更好的性能。因此現在你可以通過點擊【強制執行計劃】強制查詢7使用執行計劃。

SQL Server 2016 查詢存儲性能優化小結

搞定,我們已經解決問題了!

現在當你執行存儲過程(用80000的輸入參數值),在執行計劃里你可以看到聚集索引掃描,執行計劃只生成419個邏輯讀——很簡單,是不是?絕對不是?。。?!

微軟告訴我們只給修正SQL Server性能相關的“新方式”。你只是強制了特定的計劃,一切都還好。這個方法有個大的問題,因為性能問題的根源并沒有解決!這個問題的關鍵是因為書簽查找計劃沒有穩定性。取決于首次執行計劃默認的輸入值,執行計劃因此就被不斷重用。

通常我會建議調整下你的索引設計,創建一個覆蓋索引來保證計劃的穩定性。但強制特定執行計劃只是臨時解決問題——你還是要修正你問題的根源。

小結

不要誤解我:SQL Server 2016里的查詢存儲功能很棒,可以幫你更容易理解計劃回歸。它也會幫你“臨時”強制特定的執行計劃。但性能調優的目標還是一樣:你要找到問題根源,嘗試解決問題——不要在外面晃蕩!



注:相關教程知識閱讀請移步到MSSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品极品美女粉嫩高清在线| 2018中文字幕一区二区三区| 久久夜精品va视频免费观看| 青青草成人在线| 欧美大肥婆大肥bbbbb| 社区色欧美激情 | 国产精品成人一区二区三区吃奶| 欧美资源在线观看| 91成人性视频| 久久久久久久97| 92裸体在线视频网站| 亚洲国产女人aaa毛片在线| 在线观看欧美日韩国产| 免费91在线视频| 国产日韩欧美在线视频观看| 色综合视频网站| 国产欧美在线观看| 国产精品极品尤物在线观看| 欧美激情视频网站| 91精品国产成人www| 国产精品久久av| 日韩va亚洲va欧洲va国产| 夜夜躁日日躁狠狠久久88av| 97色在线观看免费视频| 国产精品第3页| 欧美视频在线观看免费| 亚洲精品久久久一区二区三区| 久久综合色88| 亚洲福利视频二区| 精品在线欧美视频| 国产在线98福利播放视频| 一区二区三区四区视频| 久久久久久久久网站| 欧美精品制服第一页| 欧美午夜精品久久久久久人妖| 国产亚洲美女精品久久久| 亚洲毛茸茸少妇高潮呻吟| 日韩中文字幕视频在线| 最好看的2019的中文字幕视频| 在线播放国产精品| 欧美人与性动交a欧美精品| 亚洲大尺度美女在线| 中文字幕久热精品视频在线| 日韩精品视频三区| 国产精品丝袜白浆摸在线| 91精品在线观| 亚洲国产一区二区三区在线观看| 久久久免费观看视频| 国产视频精品在线| 欧美激情aaaa| 久久韩剧网电视剧| 成人欧美在线视频| 亚洲男人天堂视频| 亚洲精品一区二区三区婷婷月| 亚洲人成欧美中文字幕| 亚洲女人天堂网| 亚洲国产精品系列| 欧美中文在线免费| 亚洲免费视频网站| 日韩亚洲国产中文字幕| 国产mv久久久| 俺去了亚洲欧美日韩| 国产网站欧美日韩免费精品在线观看| 97不卡在线视频| 亚洲一区二区三区四区在线播放| 国产欧美精品日韩精品| 亚洲欧美日韩区| 92版电视剧仙鹤神针在线观看| 这里只有精品在线观看| 国产亚洲一区二区精品| 精品国偷自产在线| 国产精品偷伦一区二区| 黑人狂躁日本妞一区二区三区| 国产又爽又黄的激情精品视频| 在线看福利67194| 欧美大肥婆大肥bbbbb| 国产精品嫩草视频| 国产成人精品久久二区二区91| 亚洲欧美国产精品va在线观看| 欧美肥臀大乳一区二区免费视频| 国产亚洲在线播放| 久久成人人人人精品欧| 久久久久久久影院| 91精品国产电影| 久久人人爽人人| 日韩av在线免播放器| 日韩少妇与小伙激情| 久久久成人精品视频| 国产精品伦子伦免费视频| 欧美极品欧美精品欧美视频| 91九色综合久久| 国产一区欧美二区三区| 亚洲一区二区黄| 国产午夜精品久久久| 国产精品久久不能| 午夜精品www| 51色欧美片视频在线观看| 久久天天躁狠狠躁夜夜av| 亚洲天堂av在线免费观看| 永久免费精品影视网站| 国产日韩在线看| 人九九综合九九宗合| 97视频网站入口| 亚洲天堂免费视频| 亚洲偷欧美偷国内偷| 欧美精品videosex极品1| 九九热99久久久国产盗摄| 欧美高清第一页| 91热精品视频| 久久久国产一区| 久久精品电影一区二区| 欧美激情一区二区三区久久久| 国产美女搞久久| 国产精品视频久久| 成人看片人aa| 日韩高清av在线| 欧美大秀在线观看| 久久亚洲精品一区| 在线观看欧美日韩国产| 欧美性猛交xxxx免费看漫画| 中文字幕欧美专区| 日韩欧亚中文在线| 精品福利在线看| 欧美日韩中文字幕在线| 国产精品一区=区| 国产一区二区三区视频免费| 国产精品成人播放| 久久久亚洲欧洲日产国码aⅴ| 亚洲午夜av电影| 成人国产亚洲精品a区天堂华泰| 国产免费成人av| 日韩hd视频在线观看| 欧美激情二区三区| 久久男人的天堂| 91国在线精品国内播放| 欧美国产亚洲视频| 日韩69视频在线观看| 欧美日韩一区二区三区在线免费观看| 孩xxxx性bbbb欧美| 欧美成人亚洲成人日韩成人| 一区二区中文字幕| 精品久久久久久久久久国产| 91精品国产91久久久久久吃药| 亚洲天堂一区二区三区| 欧美黑人国产人伦爽爽爽| 中文字幕日韩精品在线观看| 午夜欧美大片免费观看| 麻豆国产精品va在线观看不卡| 日韩在线激情视频| 国产精品一区二区性色av| 久久99热精品| 91欧美激情另类亚洲| 亚洲综合在线中文字幕| 欧美激情在线播放| 国产亚洲精品综合一区91| 欧美成人午夜激情视频| 精品久久久久久久中文字幕| 成人免费观看49www在线观看| 91色视频在线导航| 国产精品久久久久久五月尺| 国产91色在线播放| 国产91精品最新在线播放| 久久免费高清视频| 91欧美视频网站|