【乾貨】語句優化思路與流程

来源:http://www.cnblogs.com/double-K/archive/2017/12/11/8022367.html
-Advertisement-
Play Games

最近接到一個系統全面優化的工作,此系統從開發到運維到管理(伺服器配置/架構/索引設計/日常維護)等等方面均非常優秀,在之前的一些文章中很少涉及深層次語句調優的方法和思路,那麼今天補充一篇。 廢話不多說 直接上思路步驟。 步驟一: 確定重點語句 此部分詳細說明,請參見:Expert 診斷優化系列 針對 ...


  最近接到一個系統全面優化的工作,此系統從開發到運維到管理(伺服器配置/架構/索引設計/日常維護)等等方面均非常優秀,在之前的一些文章中很少涉及深層次語句調優的方法和思路,那麼今天補充一篇。

廢話不多說 直接上思路步驟。

 

步驟一: 確定重點語句

  此部分詳細說明,請參見:Expert 診斷優化系列-------------針對重點語句調索引

  • l  在SQL專家雲[全面診斷] –[慢語句]-[彙總視圖](預設頁) 中找到執行次數多的語句
  • l  結合業務找出重點功能,針對性梳理調優

 

步驟二 : 重點語句調整思路(以下方法為遞進方式)

註:以下思路適用於語句深度調優(已經規避低級設計或寫法問題,具體內容請參見 :SQL SERVER全面優化-------寫出好語句是習慣

   

  • l  在複雜存儲過程中找出慢的部分(如圖:存儲過程整體執行6秒,主要消耗在2個高消耗子語句)

 

  在SQL專家雲語句執行中觀察所產生的等待,消除語句等待(此部分涉及的點較多,請參見 全面調優系列 SQL SERVER全面優化-------Expert for SQL Server 診斷系列

 

 

  • l  定位高開銷
    • n    Set statistics io on 定位高邏輯讀部分
    • n    執行計劃中高開銷百分比
    • n    Hash join/merage join/nested join 表掃描/索引掃描次數
  • l  沒有明顯缺失索引或以添加索引後,詳細分析執行計劃
    • n    繼續分析索引(消除key lookup,index/table spool 等)
    • n    分析查詢計劃嘗試使用查詢提示(option 並行/並行度/連接方式/連接順序等)
  • l  分析語句複雜度及寫法
    • n    儘量較少表關聯數量(1.執行計劃穩定性 2.預估數量準確性 3.嵌套導致的多次掃描)
    • n    視圖/表值函數篩選條件應用(較少視圖查詢數據量)
    • n    降低視圖複雜度(多層視圖嵌套且涉及數量量大無法根據條件篩選),降低由於複雜度導致的視圖內表多次嵌套(hash join/ nested join)掃描
  • 考慮使用高成本多欄位覆蓋索引
    •  當語句複雜度高且受業務限制無法修改,則嘗試使用多列覆蓋索引來降低內層多次迴圈中的每次開銷
  • l  降低數據量與讀寫分離
    • n  當語句複雜度高且受業務限制無法修改,可以考慮降低表數據量來減少每次掃描/嵌套開銷等等
    • n  讀寫分離,報表類大查詢降低語句阻塞影響,非核心類查詢分離等

步驟三 :保證執行計劃穩定性

當上述優化都進行以後,要確保運行運行穩定,包含如下因素:

  • l  統計信息
  • l  索引碎片
  • l  參數嗅探
  • l  執行計劃重編譯
  • l  2014以上版本的新參數估計
  • l  其他多種因素

步驟四 :複雜過程中其他部分調優

  • l  複雜過程的優化可能涉及集中情況
    • n    過程中大量時間和消耗集中在1-2條語句,則針對性調優
    • n    時間及消耗分佈在多條語句,每條語句時間都不是很長,但整體步驟多,此時一般重點業務逐條優化,非重點業務優化迴圈類操作
    • n    非逐條分析,整體環境提升如參數配置、索引全面解析

註 :此部分根據自身業務情況而定,無法給出標準套路

 

另附幾篇較好的優化思路文章,供大家參考:

資料庫優化案例——————某市中心醫院HIS系統

30分鐘帶你熟練性能優化的那點兒事兒(案例說明)

SQL SERVER全面優化-------Expert for SQL Server 診斷系列

 

--------------博客地址---------------------------------------------------------------------------

診斷優化系列 http://www.cnblogs.com/double-K/

 

-----------------------------------------------------------------------------------------------------

 

  總結 : 語句的調優方法很多,內容很複雜,涉及到的點也很多,無法全部涉及,本文也許只是提供一個簡單的思路供大家參考。

      各有各的套路和方法,不喜勿噴!

      優化無止境,且行且珍惜!

-----------------------------------------------------------------------------------------------------

註:此文章為原創,歡迎轉載,請在文章頁面明顯位置給出此文鏈接!
若您覺得這篇文章還不錯請點擊下右下角的推薦,非常感謝!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 首先登陸管理員賬號,或者有DBA許可權的用戶,接下來依次: --查詢所有用戶select * from dba_users;--創建新用戶create user gpmgt identified by GPMGT; --查看所有用戶所在表空間select username,default_tables ...
  • [20171211]ora-16014 11g.txt--//上午測試了10g下備庫log_archive_dest_1參數配置VALID_FOR=(ONLINE_LOGFILES,ALL_ROLES)的錯誤.在11G也測試看看:1.環境:SCOTT@book> @ &r/ver1PORT_STRI ...
  • 筆者環境 CentOS6.9+VMware+11g 檢查是否許可權問題 輸出的正確許可權應該如下: 如果不是請按如下修改: 筆者按照這種方法已經可以重新使用sqlplus。 "參考文章" ...
  • mysql常用的hint對於經常使用oracle的朋友可能知道,oracle的hint功能種類很多,對於優化sql語句提供了很多方法。同樣,在mysql里,也有類似的hint功能。下麵介紹一些常用的。強制索引 FORCE INDEX SELECT * FROM TABLE1 FORCE INDEX ...
  • 首先,先弄清楚tnsping是什麼: Oracle Net 工具(命令)tnsping,是一個OSI會話層的工具,測試資料庫服務的命令,用來決定是否一個Oracle Net 網路服務(service)可以被接受。從某種意義上來說,tnsping 針對的 sqlnet連接,就好比為我們常用的ping ...
  • 創建自動執行存儲過程: 1.創建參數 2.刪除已有同名的作業 3. 創建作業 4.創建作業步驟 5.連接伺服器 6.創建作業調度 7.啟動作業 ALTER PROCEDURE dbo.sx_pro_AutoExecJobCreation AS Begin Declare @jobName varch ...
  • 一.背景 為了適應業務增長,資料庫數據量快速增長,性能日趨下降,穩定性不佳的實際情況,急需架構逐步演變適應未來的業務發展。 二.現狀 【穩定性】資料庫為單點,沒有高可用和穩定性方案。 【數據量大】資料庫目前400G左右,每個月大約100G的增量; 單表數據只增不刪,數據持續增長; 【業務優化,剝離難 ...
  • 用PLSQL調試存儲過程的時候,經常會遇到這個的情況,點調試後,繼續點單步都是灰色,想停下來,但是取消也要點很多次才能取消掉。 就像下麵的情況: 一直以為是個BUG,直到最近有人告訴我了真相。 出現這個問題的原因,是因為 1:調試存儲過程要發起兩個會話(運行、調試) 2:我們plsql的預設配置會話 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...