識別SQL Server 性能殺手

来源:http://www.cnblogs.com/qiaokai/archive/2017/08/02/7273781.html
-Advertisement-
Play Games

性能優化的重點在於識別定位問題,預先瞭解主要的性能殺手,能夠更快的定位到問題並將工作集中在可能的原因之上。 SQL SERVER性能殺手主要集中在如下幾類: 1.1 低質量的索引 低質量的索引通常是SQL SERVER最大的性能殺手,對於一個缺乏索引的查詢,SQL SERVER 需要處理大量的讀取和 ...


性能優化的重點在於識別定位問題,預先瞭解主要的性能殺手,能夠更快的定位到問題並將工作集中在可能的原因之上。

 

SQL SERVER性能殺手主要集中在如下幾類:

1.1   低質量的索引

低質量的索引通常是SQL SERVER最大的性能殺手,對於一個缺乏索引的查詢,SQL SERVER 需要處理大量的讀取和計算;這樣導致磁碟、記憶體、CUP上有很大的開銷,並且會顯著的增加了查詢執行時間。

 

1.2   不精確的統計信息

統計信息是謂詞引用的列中的數據分佈,其存儲的方式為柱狀圖;柱狀圖是顯示數據分佈於不同分類中頻度的一種統計結構。索引的有效性完全取決於索引列的統計信息,如有沒有統計信息,SQL SERVER 內建的查詢優化器就不能精確的估計查詢影響的行數,此時查詢優化器就非常的低效。

 

1.3   過多的阻塞與死鎖

SQL SERVER 完全兼用於原子性、一致性、隔離性、永久性,所以資料庫引擎會確保併發事務被正確的互相隔離。預設情況下,一個事務所看見的數據是另一個事務修改之前或者修改之後的狀態—它不會看到中間狀態。

    因為這種隔離性,當多個事務以一種相容的方法併發訪問公用資源時,資料庫中會發生阻塞。當兩個資源嘗試升級或擴展加鎖的資源並且與另一個衝突時,就會發生死鎖。查詢引擎確定回滾開銷最低的進程並選擇其為死鎖犧牲品。犧牲品需要再次提交請求才能正常執行完成。這就導致開銷時間較長。

 

1.4   不基於數據集的操作

T-SQL是一種數據集的腳本語言,操作數據是在數據集上進行。這需要我們從數據列上考慮問題而不是從數據行上思考問題。避免在操作中使用游標和迴圈,而是需要多使用連接於子查詢。

 

1.5   低質量的查詢設計

索引的有效性取決於編寫的SQL 查詢語句;如果SQL從一個表中讀取了過多的行或者指定的過濾條件返回了超過所需要的大結果集,都將使索引變得無效。為了能更好的使用索引,必須編寫高質量的SQL查詢語句並做到按需取數。

 

1.6   低質量的資料庫設計

    資料庫應該合理的規範化以增進資料庫檢索的性能並減少阻塞。一個不合理的設計會導致數據的重覆存儲,一個過渡規範化的資料庫會導致讀取數據所需的連接非常多;一個合理規範化的資料庫是高質量查詢的基石。

 

1.7   過多的碎片

    數據存儲的基本單位是頁,由於頻繁的頁分割使得頁中包括了無法存儲數據的空白區域稱為碎片;碎片會引起讀操作次數的增加而影響性能(一次讀取的是一個頁)。

 

1.8   不可重用的執行計劃

為了有效的執行查詢,SQL SERVER 會在編譯的時候生成一個優化的執行計劃,該執行計劃會緩存在記憶體中,因而其可以重用。但是如果該查詢設計為不能插入變數值,相同的查詢以不同的變數值重新提交時,SQL SERVER會重新生成新的執行計劃,這個過程會耗掉一線性能。因此SQL SERVER 緩存或重用執行計劃的方式提交SQL查詢會對性能有一定的優化。

 

1.9   低質量的執行計劃

    一個不好的執行計劃有時可能是一個真正的殺手,不好的計劃常常是由被稱為參數嗅探的進程造成的,這個進程來自於查詢優化器用於根據統計確定最佳計劃的過程。理解統計信息是很重要的。

 

1.10     頻繁重編譯計劃

存儲過程的重新編譯會導致執行計劃的重覆生成,該過程很耗費性能,所以一般情況下不要將存儲過程設計為重編譯。

 

1.11     游標的錯誤使用

     游標是一種非集合的操作,會給SQL SERVER 增加大量的開銷;儘可能使用基於數據集的操作。

 

1.12     錯誤配置資料庫日誌

     為了達到最佳的性能,SQL SERVER 很大程度上依賴於對資料庫日誌的高效訪問。因此合理的日誌配置方法也很重要。

 

1.13     過多使用或者錯誤配置TEMPDB

     每一個SQL SERVER 實例都只有一個tempdb,因為涉及用戶對象(如臨時表與表變數)、系統對象(如游標或用於連接的hash表)的操作,以及排序和行版本控制等操作都使用tempdb資料庫,所以tempdb有時候也可能成為一個瓶頸。所有這些操作和其他可能使用的操作都可能導致tempdb中的空間、I/0和爭用問題。因此tempdb的正確配置對於查詢性能也有較大的影響。


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

-Advertisement-
Play Games
更多相關文章
  • 摘自:《高性能Mysql》 1. 哈希索引基於哈希表實現,只有精確的匹配索引所有列的查詢才有效,對於每一行數據,存儲引擎會對所有的索引列計算一個哈希碼,並將哈希碼存儲在索引中,同時在哈希表中保存只想每個數據行指針 mysql中,只有memory引擎顯示支持哈希索引,並且支持非唯一哈希索引。也是mem ...
  • 多表查詢必然要用到多表關聯 多表關聯 分三類: A:內部連接 join 或inner join B:外部鏈接 外部連接又分為兩類 :左外連接 left join 和右外連接 right join C:交叉連接 cross join 以下 舉例說明 有兩張表 格 一張學生的 一張老師的 一張中間表的 ...
  • 介紹 Always On 可用性組活動輔助功能包括支持在輔助副本上執行備份操作。 備份操作可能會給 I/O 和 CPU 帶來很大的壓力(使用備份壓縮)。 將備份負荷轉移到已同步或正在同步的輔助副本後,您可以使用承載第一層工作負荷的主副本的伺服器實例上的資源,您可以創建主資料庫的任何類型的備份。 也可 ...
  • 1、課程名稱:MySQL 1.1、 MySQL資料庫學習準備 (1) 什麼是資料庫 資料庫,顧名思義,是存入數據的倉庫。只不過這個倉庫是在電腦存儲設備上的,而且數據是按一定格式存放的。指長期儲存在電腦內的、有組織的、可共用的數據集合。其組織方式可支持對數據的有效存取。 當人們收集了大量的數據後, ...
  • 文章目錄 遇到的問題 使用SQLServer Profiler監控資料庫 SQL1:查找最新的30條告警事件 SQL2:獲取當前的總報警記錄數 有哪些SQL語句會導致CPU過高? 查看SQL的查詢計劃 選擇top記錄時,儘量為order子句的欄位建立索引 查看SQL語句CPU高的語句 通過建立相關索 ...
  • 直接上例子: a表 b表 ab表 一、left join 過程(以 select * from a left join ab on a.a_id = ab.a_id): 用a中的記錄根據on條件聯合ab的記錄進行篩選並做笛卡爾積,過稱為 篩選過程: a: 1,"lige" ab: 1,3 1,2 a ...
  • 原始數據:要求將ASSETUNITID拆成多行展示,r_id是主鍵 展示效果:將ASSETUNITID拆成多行,別名取為assid 實現的sql: selectr_id,INSTANCEID,o_name,o_code,o_type,d_flag,imp_date,pipe_id,src_r_id, ...
  • Buffer Pool擴展簡介 Buffer Pool擴展是buffer pool 和非易失的SSD硬碟做連接。以SSD硬碟的特點來提高隨機讀性能。 在Buffer Pool 擴展之前,SQL Server 從磁碟中讀入數據,並且存放在buffer pool中以供讀取和修改,修改完之後臟數據還是放在 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...