濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > Sql Server 數(shù)據(jù)庫(kù)索引整理語(yǔ)句,自動(dòng)整理數(shù)據(jù)庫(kù)索引

Sql Server 數(shù)據(jù)庫(kù)索引整理語(yǔ)句,自動(dòng)整理數(shù)據(jù)庫(kù)索引

熱門(mén)標(biāo)簽:長(zhǎng)沙智能外呼系統(tǒng) 知名電銷(xiāo)機(jī)器人價(jià)格 菏澤語(yǔ)音電銷(xiāo)機(jī)器人加盟公司 外呼系統(tǒng)改進(jìn) 廣東防封卡外呼系統(tǒng)原理是什么 分享百度地圖標(biāo)注多個(gè)位置 湖南電腦外呼系統(tǒng)平臺(tái) 地圖標(biāo)注牌 電銷(xiāo)機(jī)器人公司 需要哪些牌照
在一個(gè)大型數(shù)據(jù)庫(kù)中,數(shù)據(jù)的更改是非常頻繁的。
而建立在這些數(shù)據(jù)上的索引也是需要經(jīng)常去維護(hù)的。
否則這這些數(shù)據(jù)索引就起不到起應(yīng)起的作用。甚至?xí)蔀閿?shù)據(jù)庫(kù)本身的負(fù)擔(dān)。
我們就要定期的對(duì)數(shù)據(jù)庫(kù)的索引進(jìn)行維護(hù) 我在MSDN上發(fā)現(xiàn)了這個(gè)腳本不過(guò)其中有些小問(wèn)題我已經(jīng)修正 大家可以使用這個(gè)腳本對(duì)數(shù)據(jù)庫(kù)的索引進(jìn)行日常維護(hù)
復(fù)制代碼 代碼如下:

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

這個(gè)腳本在運(yùn)行時(shí) 會(huì)建立一個(gè)表 work_to_do 整理完畢后會(huì)自動(dòng)刪除這個(gè)表。如果大家不喜歡這樣的話也可以用 一個(gè) 臨時(shí)表解決 .
您可能感興趣的文章:
  • 通過(guò)T_sql語(yǔ)句向其中一次填入一條數(shù)據(jù)或一次填入多條數(shù)據(jù)的方式填充數(shù)據(jù)
  • sql語(yǔ)句查詢數(shù)據(jù)庫(kù)中的表名/列名/主鍵/自動(dòng)增長(zhǎng)值實(shí)例
  • Mysql 自動(dòng)增加設(shè)定基值的語(yǔ)句
  • SQL語(yǔ)句實(shí)現(xiàn)查詢并自動(dòng)創(chuàng)建Missing Index
  • SQL語(yǔ)句中公共字段的自動(dòng)填充方法

標(biāo)簽:商洛 珠海 天水 福建 呼和浩特 美容院 西寧 泉州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Sql Server 數(shù)據(jù)庫(kù)索引整理語(yǔ)句,自動(dòng)整理數(shù)據(jù)庫(kù)索引》,本文關(guān)鍵詞  Sql,Server,數(shù)據(jù)庫(kù),索引,整理,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Sql Server 數(shù)據(jù)庫(kù)索引整理語(yǔ)句,自動(dòng)整理數(shù)據(jù)庫(kù)索引》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于Sql Server 數(shù)據(jù)庫(kù)索引整理語(yǔ)句,自動(dòng)整理數(shù)據(jù)庫(kù)索引的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    松原市| 常熟市| 中超| 新泰市| 昌乐县| 仙居县| 德安县| 区。| 沙坪坝区| 新泰市| 拉萨市| 平湖市| 钦州市| 宜兰县| 瑞金市| 遂宁市| 马公市| 兴国县| 衡东县| 崇州市| 宜良县| 新源县| 马公市| 太保市| 湟源县| 曲水县| 桐柏县| 九龙坡区| 剑阁县| 临湘市| 三江| 临泽县| 东明县| 长武县| 长沙市| 收藏| 公安县| 镇巴县| 安塞县| 新巴尔虎右旗| 叶城县|