亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

怎樣檢查fragmentation

標簽:
SQL Server

可以运行下面SQL语句:

 

SELECT dbschemas.[name] AS 'Schema',  dbtables.[name] AS 'Table',  dbindexes.[name] AS 'Index', indexstats.index_type_desc, indexstats.avg_fragmentation_in_percent, indexstats.page_countFROM sys.dm_db_index_physical_stats (DB_ID(), NULL, NULL, NULL, NULL) AS indexstatsINNER JOIN sys.tables dbtables ON (dbtables.[object_id] = indexstats.[object_id])INNER JOIN sys.schemas dbschemas ON (dbtables.[schema_id] = dbschemas.[schema_id])INNER JOIN sys.indexes AS dbindexes ON (dbindexes.[object_id] = indexstats.[object_id]AND indexstats.index_id = dbindexes.index_id)WHERE indexstats.database_id = DB_ID()ORDER BY indexstats.avg_fragmentation_in_percent DESC

View Code

 
参考运行后这个avg_fragmentation_in_percent值,肯定是越小越好:

 

以下内容于2014-10-07 13:15分更新:
Insus.NET 写了一个存储过程,把avg_fragmentation_in_percent值大于或等于30的,rebuild索引:

 

CREATE PROCEDURE [dbo].[usp_RebuildIndex]ASBEGIN    IF OBJECT_ID('#t') IS NOT NULL        DROP TABLE #t    CREATE TABLE #t    (    [ID] INT IDENTITY(1,1) PRIMARY KEY NOT NULL,    [Table] NVARCHAR(128) NOT NULL,    [Index] NVARCHAR(128) NOT NULL    )    INSERT INTO #t ([Table],[Index]) SELECT  dbtables.[name],dbindexes.[name]     FROM sys.dm_db_index_physical_stats (DB_ID(), NULL, NULL, NULL, NULL) AS indexstats    INNER JOIN sys.tables dbtables ON (dbtables.[object_id] = indexstats.[object_id])    INNER JOIN sys.schemas dbschemas ON (dbtables.[schema_id] = dbschemas.[schema_id])    INNER JOIN sys.indexes AS dbindexes ON (dbindexes.[object_id] = indexstats.[object_id]    AND indexstats.index_id = dbindexes.index_id)    WHERE indexstats.database_id = DB_ID() AND dbindexes.[name] IS NOT NULL AND indexstats.avg_fragmentation_in_percent >= 30    DECLARE @r INT = 1, @rs INT = 0    SELECT @rs = MAX([ID]) FROM #t    WHILE @r <= @rs    BEGIN        DECLARE @table NVARCHAR(128), @index NVARCHAR(128)        SELECT @table = [Table],@index = [Index] FROM #t WHERE [ID] = @r        EXECUTE('ALTER INDEX '+@index +' ON '+ @table +' REBUILD;')        SET @r = @r + 1    ENDENDGO

View Code

 

點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消