程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> 其他數據庫知識 >> MSSQL >> 晉升SQL Server速度 整頓索引碎片

晉升SQL Server速度 整頓索引碎片

編輯:MSSQL

晉升SQL Server速度 整頓索引碎片。本站提示廣大學習愛好者:(晉升SQL Server速度 整頓索引碎片)文章只能為提供參考,不一定能成為您想要的結果。以下是晉升SQL Server速度 整頓索引碎片正文


憑經歷,這是索引碎片成績。檢討索引碎片DBCC SHOWCONTIG(表),獲得以下成果:

DBCC SHOWCONTIG 正在掃描 'A' 表...
表: 'A'(884198200);索引 ID: 1,數據庫 ID: 13
已履行 TABLE 級其余掃描。
- 掃描頁數.....................................: 3127
- 掃描擴大盤區數...............................: 403
- 擴大盤區開關數...............................: 1615
- 每一個擴大盤區上的均勻頁數.....................: 7.8
- 掃描密度[最好值:現實值]....................: 24.20%[391:1616]
- 邏輯掃描碎片.................................: 68.02%
- 擴大盤區掃描碎片.............................: 38.46%
- 每頁上的均勻可用字節數.......................: 2073.2
- 均勻頁密度(完全)...........................: 74.39%
DBCC 履行終了。假如 DBCC 輸入了毛病信息,請與體系治理員接洽。


由上我們看出,邏輯掃描碎片和擴大盤區掃描碎片都異常年夜,果真須要對索引碎片停止處置了。

普通有兩種辦法處理,一是應用DBCC INDEXDEFRAG整頓索引碎片,二是應用DBCC DBREINDEX重建索引。兩者各有優缺陷。挪用微軟的原話以下:
DBCC INDEXDEFRAG 敕令是聯機操作,所以索引只要在該敕令正在運轉時才可用。並且可以在不喪失已完成任務的情形下中止該操作。這類辦法的缺陷是在從新組織數據方面沒有集合索引的除去/從新創立操作有用。

從新創立集合索引將對數據停止從新組織,其成果是使數據頁填滿。填滿水平可使用 FILLFACTOR 選項停止設置裝備擺設。這類辦法的缺陷是索引在除去/從新創立周期內為脫機狀況,而且操作屬原子級。假如中止索引創立,則不會從新創立該索引。

也就是說,要想取得好的後果,照樣得用重建索引,所以決議重建索引。
DBCC DBREINDEX(表,索引名,填充因子)
第一個參數,可所以表名,也能夠是表ID。
第二個參數,假如是'',表現影響該表的一切索引。
第三個參數,填充因子,即索引頁的數據填充水平。假如是100,表現每個索引頁都全體填滿,此時select效力最高,但今後要拔出索引時,就得挪動前面的一切頁,效力很低。假如是0,表現應用先前的填充因子值。

DBCC DBREINDEX(A,'',100)
從新測試查詢速度,飛快。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved