濮阳杆衣贸易有限公司

主頁 > 知識庫 > SqlServer 索引自動優(yōu)化工具

SqlServer 索引自動優(yōu)化工具

熱門標簽:威海智能語音外呼系統(tǒng) 西安青牛防封電銷卡 溫州語音外呼系統(tǒng)代理 山西語音外呼系統(tǒng)價格 智能語音外呼系統(tǒng)哪個牌子好 北京辦理400電話多少 400電話申請需要開戶費嗎 南京電銷外呼系統(tǒng)運營商 重慶防封電銷機器人供應(yīng)商
鑒于人手嚴重不足(當時算兩個半人的資源),打消了逐個庫手動去改的念頭。當前的程序結(jié)構(gòu)不允許搞革命的做法,只能搞搞改良,所以準備搞個自動化工具去處理。原型剛開發(fā)完,開會的時候以拿出來就遭到運維DBA團隊強烈抵制,具體原因不詳。最后無限延期。這里把思路分享下。歡迎拍磚。

  整個思路是這樣的,索引都是為查詢和更新服務(wù)的,但是不合適的索引又會對插入和更新帶來負面影響。面對表上現(xiàn)有的索引想識別那些是有效的不太可能。那么根據(jù)現(xiàn)有的數(shù)據(jù)使用情況重建所有的新索引不就解決了嘛。根據(jù)查詢生成全新索引,然后和現(xiàn)有對比,不吻合的全部刪除,原來沒有的創(chuàng)建。雖然說對于正在運行的系統(tǒng)來說風(fēng)險還是蠻大的。但是可以做臨界測試嘛。
  
具體解決方案如下:

  首先在熱備的數(shù)據(jù)庫服務(wù)器上定期抓取緩存的執(zhí)行計劃(原本想抓取SQL發(fā)現(xiàn)有些SQL實在摻不忍睹,沒有自動化解析的可能性),然后連同該執(zhí)行的執(zhí)行次數(shù)即表的統(tǒng)計信息一起down到一個備用服務(wù)器的數(shù)據(jù)表中。

  執(zhí)行計劃積累幾次后,開始解析。由于執(zhí)行計劃是格式良好的XML文件,加上微軟提供執(zhí)行計劃的XSD文件。我們可以反向推出各節(jié)點對應(yīng)的SQL謂詞(這個XSD到現(xiàn)在都沒找到官方的說明,只能反向推出關(guān)聯(lián))。例如建立索引我們比較關(guān)心三類謂詞,分別為:Select,Join,Where。 只要拿到這些我們就能建立良好的索引。原理很簡單,Join和Where都是索引鍵的依據(jù),而Select可以斟請?zhí)砑拥絀ndex的Include中。
  
  解析的時候也不是針對單個執(zhí)行計劃,而是將所有執(zhí)行計劃全分解后進行統(tǒng)計處理。好處就是能夠知道那些表字段被引用的最多,那些是外鍵列。那些數(shù)據(jù)被反復(fù)查詢。例如可以得出TableA的Col1列在一天的業(yè)務(wù)過程中被Join了10W次,被Where2W次。而Col2則被Select了10W次,僅僅被Where了100次。這樣我們建立索引的基礎(chǔ)就是基于表的而不是基于單個查詢的。最終生成的Index將權(quán)衡查詢頻率和查詢的重要性,如果某個業(yè)務(wù)查詢特別重要,但執(zhí)行頻率不高我們可以提供權(quán)重,優(yōu)先建立索引。當然創(chuàng)建Index還要參考表的數(shù)據(jù)分布以決定Index中字段的順序。

  好了,準備工作完成,開始建索引。當前擁有的條件,表數(shù)據(jù)分布,表字段分別被查詢引用次數(shù)(Select,Join,Where),以及這些SQL謂詞出現(xiàn)的次數(shù)。根據(jù)這些如何創(chuàng)建索引開始的想法是逐個分析,考慮所有可能性然后創(chuàng)建。發(fā)現(xiàn)這種方式只適合人腦,讓電腦做得先讓電腦的智商增長到120以上才有可行性。發(fā)現(xiàn)逆向思維這里同樣大有用處,既然不能一下子創(chuàng)建最合適的,那我們就根據(jù)執(zhí)行計劃得出的組合創(chuàng)建所有的Index組合。凡是Join和Where都放到Index的Key里。例如:
  select t1.A, t1.B, t1.C, t2.J, t2.k from Table1 t1 Join Table1 t2 on t1.A = t2.j Where t1.A = 'param'

草創(chuàng)的索引就是:

  Index(A,B)includ(C) 和 Index(j)include(j,k)

關(guān)于Select如果是小數(shù)據(jù)類型且Alter的執(zhí)行計劃中該數(shù)據(jù)修改頻率很小的都放到Include里去進去。大數(shù)據(jù)類型和修改比較頻繁的就算了。這樣我們剔除相互覆蓋的。部分重疊的,部分重疊到底保留那一個參考執(zhí)行頻率和查詢重要性。差異很小的就合并并為一個,如:

  1.Index (A,B,C)Include(D)
  2.Index(A,B,D)Include(C)

直接合并為:

  Index(A,B)Include(C,D)

當然如果Alert的特別少也可以合并成Index(A,B,C,D)這個要參考C,D字段的修改頻率。和主鍵重疊的剔除。這樣留下的基本上就是我們需要的索引了。
  
  對比現(xiàn)有索引進行甄別覆蓋的過程就略過。簡單的拉出來Create Index 進行解析處理就好了。發(fā)布的時候很簡單。寫個腳本在業(yè)務(wù)比較少的時候做Drop和Create就完成了。項目源代碼因為設(shè)計到公司的保密問題就不上傳了。一個注意的地方對于簡單查詢的SQL執(zhí)行計劃緩存的時候會比較短且一旦緩存不夠就會被清理掉。要注意這些SQL的執(zhí)行頻率的誤差。

  SqlserverR2 XSD:http://schemas.microsoft.com/sqlserver/2004/07/showplan/sql2008/showplanxml.xsd
 
 總結(jié)的節(jié)點映射列舉如下:

    查詢sql執(zhí)行計劃都包含在節(jié)點“StmtSimple”中,如果沒有這個節(jié)點一般就是其它類型的SQL的執(zhí)行計劃。

    Join關(guān)聯(lián)的節(jié)點和自身類型有關(guān)一般包含在Hash,Marger中,如何Join同時又是Where條件的話則會出現(xiàn)在SeekKey和Compare節(jié)點中,因為Join的列都是成對出現(xiàn),這里很容易識別,有一個是參數(shù)(@開頭)或常量(type="Const")則必定是Where條件。
    
    Select最終輸出字段比較容易找到,第一個OutputList節(jié)點就是。

    需要注意的是有因為一般列每個ColumnReference都包含庫名,表名,列信息,但是系統(tǒng)表則不會。注意剔除。
您可能感興趣的文章:
  • 人工智能自動sql優(yōu)化工具--SQLTuning for SQL Server
  • sql語句優(yōu)化之SQL Server(詳細整理)
  • SQL Server中的SQL語句優(yōu)化與效率問題
  • SQL Server優(yōu)化50法匯總
  • SQL Server游標的使用/關(guān)閉/釋放/優(yōu)化小結(jié)
  • 優(yōu)化 SQL Server 索引的小技巧
  • SQL Server并行操作優(yōu)化避免并行操作被抑制而影響SQL的執(zhí)行效率

標簽:新余 中衛(wèi) 貸款群呼 黃山 宜春 濟寧 河源 金昌

巨人網(wǎng)絡(luò)通訊聲明:本文標題《SqlServer 索引自動優(yōu)化工具》,本文關(guān)鍵詞  SqlServer,索引,自動,優(yōu)化,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SqlServer 索引自動優(yōu)化工具》相關(guān)的同類信息!
  • 本頁收集關(guān)于SqlServer 索引自動優(yōu)化工具的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    奉节县| 闽清县| 涟水县| 宝清县| 北海市| 关岭| 龙川县| 鄂伦春自治旗| 阳江市| 潼南县| 河源市| 太康县| 罗城| 阳谷县| 横山县| 临泽县| 赣州市| 昌乐县| 西昌市| 盐亭县| 闻喜县| 邵武市| 商南县| 察雅县| 连城县| 株洲市| 彭泽县| 临城县| 黄陵县| 连山| 盱眙县| 隆尧县| 镇平县| 达拉特旗| 郧西县| 阿瓦提县| 株洲市| 大城县| 贵溪市| 马鞍山市| 吉水县|