一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Sql Server - Sql Server 數據庫索引整理語句,自動整理數據庫索引

Sql Server 數據庫索引整理語句,自動整理數據庫索引

2019-11-10 16:31mssql教程網 Sql Server

我們就要定期的對數據庫的索引進行維護 我在MSDN上發現了這個腳本不過其中有些小問題我已經修正 大家可以使用這個腳本對數據庫的索引進行日常維護

在一個大型數據庫中,數據的更改是非常頻繁的。 
而建立在這些數據上的索引也是需要經常去維護的。 
否則這這些數據索引就起不到起應起的作用。甚至會成為數據庫本身的負擔。 
我們就要定期的對數據庫的索引進行維護 我在MSDN上發現了這個腳本不過其中有些小問題我已經修正 大家可以使用這個腳本對數據庫的索引進行日常維護 

復制代碼代碼如下:


SET NOCOUNT ON; 
DECLARE @objectid int; 
DECLARE @indexid int; 
DECLARE @partitioncount bigint; 
DECLARE @schemaname sysname; 
DECLARE @objectname sysname; 
DECLARE @indexname sysname; 
DECLARE @partitionnum bigint; 
DECLARE @partitions bigint; 
DECLARE @frag float; 
DECLARE @command varchar(8000); 
DECLARE @dbId int; 
-- ensure the temporary table does not exist 
IF EXISTS (SELECT name FROM sys.objects WHERE name = 'work_to_do') 
DROP TABLE work_to_do; 
-- conditionally select from the function, converting object and index IDs to names. 
set @dbId=DB_ID(); 
SELECT 
object_id AS objectid, 
index_id AS indexid, 
partition_number AS partitionnum, 
avg_fragmentation_in_percent AS frag 
INTO work_to_do FROM sys.dm_db_index_physical_stats (@dbId, NULL, NULL , NULL, 'LIMITED') 
WHERE avg_fragmentation_in_percent > 10.0 AND index_id > 0; 
-- Declare the cursor for the list of partitions to be processed. 
DECLARE partitions CURSOR FOR SELECT * FROM work_to_do; 

-- Open the cursor. 
OPEN partitions; 

-- Loop through the partitions. 
FETCH NEXT 
FROM partitions 
INTO @objectid, @indexid, @partitionnum, @frag; 

WHILE @@FETCH_STATUS = 0 
BEGIN; 
SELECT @objectname = o.name, @schemaname = s.name 
FROM sys.objects AS o 
JOIN sys.schemas as s ON s.schema_id = o.schema_id 
WHERE o.object_id = @objectid; 

SELECT @indexname = name 
FROM sys.indexes 
WHERE object_id = @objectid AND index_id = @indexid; 

SELECT @partitioncount = count (*) 
FROM sys.partitions 
WHERE object_id = @objectid AND index_id = @indexid; 

-- 30 is an arbitrary decision point at which to switch between reorganizing and rebuilding 
IF @frag < 30.0 
BEGIN; 
SELECT @command = 'ALTER INDEX [' + @indexname + '] ON ' + @schemaname + '.[' + @objectname + '] REORGANIZE'; 
IF @partitioncount > 1 
SELECT @command = @command + ' PARTITION=' + CONVERT (CHAR, @partitionnum); 

EXEC (@command); 
END; 

IF @frag >= 30.0 
BEGIN; 
SELECT @command = 'ALTER INDEX [' + @indexname +'] ON ' + @schemaname + '.[' + @objectname + '] REBUILD'; 
IF @partitioncount > 1 
SELECT @command = @command + ' PARTITION=' + CONVERT (CHAR, @partitionnum); 

EXEC (@command); 
END; 
PRINT 'Executed ' + @command; 

FETCH NEXT FROM partitions INTO @objectid, @indexid, @partitionnum, @frag; 
END; 
-- Close and deallocate the cursor. 
CLOSE partitions; 
DEALLOCATE partitions; 

-- drop the temporary table 
IF EXISTS (SELECT name FROM sys.objects WHERE name = 'work_to_do') 
DROP TABLE work_to_do; 
GO 


這個腳本在運行時 會建立一個表 work_to_do 整理完畢后會自動刪除這個表。如果大家不喜歡這樣的話也可以用 一個 臨時表解決 .

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 俄罗斯一级毛片免费播放 | 99爱视频| 暖暖 免费 高清 日本 在线1 | 国产精品久久久久这里只有精品 | 岛国最新资源网站 | 日日骑夜夜骑 | 色哟哟在线视频 | 青青色在线观看 | 国产福利自产拍在线观看 | 亚洲欧美日韩另类在线 | 秋霞理论一级在线观看手机版 | 夫妇野外交换激情 | 国产精品制服丝袜白丝www | 男人香蕉好大好爽视频 | 午夜伦伦电影理论片大片 | 欧美日韩免费一区二区在线观看 | 大妹子最新视频在线观看 | 成人看片免费无限观看视频 | 特级夫妻大片免费在线播放 | 日本免费不卡在线一区二区三区 | 美女校花被调教出奶水 | 公园暴露娇妻小说 | 好女孩韩剧免费观看 | 亚洲国产精品综合久久一线 | 日本黄色网页 | 九九热免费在线观看 | 成人在线视频国产 | 日本老熟老太hd | 国产一卡2卡3卡四卡国色天香 | 色哟哟精品 | 九九九九在线精品免费视频 | 北条麻妃一区 | 欧美一级视频免费观看 | 色在线看 | 亚洲一级片在线播放 | 女老板用丝袜脚夹我好爽 | 香蕉免费一区二区三区在线观看 | 国产成人精品午夜免费 | 亚洲 欧美 国产 综合 播放 | 韩国甜性涩爱在线播放 | 91九色丨porny丨制服 |