SQL Server 2016升級遷移過程中效能問題解決案例
日常執行的批次更新作業,平日是5分鐘之內結束,今天出現超過30分鐘沒結束的情況,實際執行3個小時以上,應用程式超時報錯。
資料庫版本:SQL Server 2016企業版
問題SQL:
declare @batch integer, @min integer, @max integer, @count integer select @min = 1, @count = count(*), @batch = 5000, @max = 5000 FROM dbo.MarketingRecipientEvents Update MarketingRecipient SET DateTrackedURLClicked = mre.EventDate FROM MarketingRecipient mr INNER JOIN dbo.MarketingRecipientEvents mre on mr.CustomerID = mre.ExternalRecipientID WHERE mr.MarketingScheduleID = 364 AND mre.EventType in ('CLICKED') AND mr.DateTrackedURLClicked IS NULL AND mre.MarketingRecipientEventsID between @min and @max
問題表上MarketingRecipient上有兩個相同覆蓋列索引,正常情況下使用出問題的時候使用
ix_MarketingRecipient_MarketingScheduleID_CustomerID 進行Nested Loop 連線,出問題的時候使用
IX_MarketingRecipient_MarketingScheduleID_DateMessageBounced進行Nested Loop連線
CREATE NONCLUSTERED INDEX [ix_MarketingRecipient_MarketingScheduleID_CustomerID] ON [dbo].[MarketingRecipient] ( [MarketingScheduleID] ASC, [CustomerID] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, SORT_IN_TEMPDB = OFF, DROP_EXISTING = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON, FILLFACTOR = 90) ON [DATA] GO CREATE NONCLUSTERED INDEX [IX_MarketingRecipient_MarketingScheduleID_DateMessageBounced] ON [dbo].[MarketingRecipient] ( [MarketingScheduleID] ASC ) INCLUDE ( [CustomerID], [DateMessageBounced], [DateMessageSent], [DateEmailOpened], [DateEmailBlocked], [MarketingRecipientID], [DateTrackedURLClicked])
問題執行計劃:
檢視執行計劃對應的統計資訊:
SELECT sp.stats_id ,object_name(s.object_id) object_name ,object_schema_name(s.object_id) schema_name ,name ,filter_definition ,last_updated ,rows ,rows_sampled ,rows_sampled*100/rows as [percent] ,steps ,unfiltered_rows ,modification_counter ,sp.persisted_sample_percent FROM sys.stats s CROSS APPLY sys.dm_db_stats_properties(s.object_id, s.stats_id) AS sp WHERE 1=1 and modification_counter < rows/5 + 500 and modification_counter > sqrt(rows*1000) and object_schema_name(s.object_id) = 'dbo' and rows > 500 and object_name(s.object_id)= 'MarketingRecipient';
發現modification_counter列的值不低:
目前資料庫剛遷移到2016版本,但是compatibility_level依舊是120並且沒有啟用trace 2371,所以,自動更新統計資訊的邏輯是:
更新行>500+錶行數*20% = 500+ 36891356*20%=7378771, 目前行數5718611不滿足條件,所以統計資訊不完善導致執行計劃異常,最佳化器並沒有捕捉到
如果使用新的自動更新統計資訊邏輯:
更新行> √錶行數*1000= √36891356*1000=192071, 5718611滿足條件,驗證一下:不改程式碼的情況下給SQL加plan guide:
OPTION (QUERYTRACEON 2371)
發現統計資訊在編譯期間自動更新,並且生成正確的執行計劃。
本例是資料庫從2014企業版到2016企業版升級過程中間狀態造成的效能問題,生產環境如果要啟用compability_level=130,
在2016環境下建議以下步驟
-
先啟用querystore建立基線,收集足夠的統計資料。
-
更改 compability_level=130
-
對比基線資料,捕獲變更的計劃進行針對性的query plan force操作,固定到之前的基線。
在沒有升級到compability_level=130的情況下,建議建立DBA更新統計資訊的job,每晚根據新的演算法更新過期的統計資訊。
也可以利用
中的 進行統計資訊維護,利用新的引數:@StatisticsModificationLevel來設定更改行數佔表總行數百分比。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69950462/viewspace-2666108/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 兩款工具解決SQL Server遷移問題DJSQLServer
- 雲端遷移過程中的技術問題和解決思路
- 使用SQL SERVER儲存過程實現歷史資料遷移SQLServer儲存過程
- munium學習過程中問題解決
- 案例分析:700G SQL Server資料庫遷移HGSQLServer資料庫
- SQL Server升級和遷移的三個技巧GZSQLServer
- SQL Server資料庫遷移SQLServer資料庫
- sql server資料庫附加錯誤的解決過程SQLServer資料庫
- 教程:使用遷移學習來解決影像問題!遷移學習
- 解決Oracle資料庫遷移後的伺服器負載效能問題JSOracle資料庫伺服器負載JS
- 跨越異構鴻溝,Redis 遷移同步過程中的挑戰與解決方案Redis
- OBIEE10g跨平臺遷移過程及問題總結
- SQL SERVER 學習過程(一)SQLServer
- sql server資料庫連線失敗/無法附加解決過程SQLServer資料庫
- SQL Server 資料訪問策略:儲存過程QCSQLServer儲存過程
- 如何捕獲問題SQL解決過度CPU消耗的問題SQL
- SQL Server常見問題介紹及快速解決建議SQLServer
- 淺談SQL Server中的快照問題SQLServer
- 遷移學習中的BN問題遷移學習
- Oracle 遷移到 OB 過程中的函式改造案例Oracle函式
- SQL Server 2016資料庫快照代理過程詳解SQLServer資料庫
- Microsoft SQL Server 遷移利器,Babelfish for Aurora PostgreSQL 上線!ROSSQLServerBabel
- SQL server儲存過程函式SQLServer儲存過程函式
- 聊聊國產資料庫遷移中的表連線效能問題資料庫
- 在效能測試的過程中會遇到哪些問題?
- 透過MySQL Workbench 將 SQL Server 遷移到GreatSQLMySqlServer
- 記一次 Composer 問題的解決過程!!
- 解決Java執行過程中拋簽名異常的問題Java
- Android開發過程中遇到的問題以及解決辦法 how toAndroid
- 最全weblogic升級與遷移改造常見問題Web
- sql多參問題解決SQL
- SQL Server 資料庫最小當機遷移方案GESQLServer資料庫
- Composer 使用過程中遇到的問題和解決方案
- 【能力提升】SQL Server常見問題介紹及快速解決建議SQLServer
- 達夢儲存過程效能問題定位儲存過程
- 企業資訊系統在遷移過程中,資料遷移要注意什麼?
- Sql Server 資料庫中呼叫dll檔案的過程SQLServer資料庫
- Ms Sql Server查詢儲存過程中的內容SQLServer儲存過程