怎樣將索引碎片數量降至最低_Mssql數據庫教程
推薦:SQL Server中, DateTime (日期)型操作的 SQL語法這兩天操作SQL Server的數據,需求是將一個日期類型字段的時、分、秒去處,即 ‘2007-11-07 16:41:35.033’ 改為‘2007-11-07 00:00:00‘,所以查詢了一下網上對DateTime類型操作的SQL語法,發現實現這個功能很簡單。 update YourTable set YourDateColumn
索引碎片能增大索引樹的大小,增加不必要的IO,所以每隔一段時間對索引碎片進行檢查時很有必要的。下面一個示例一起來分析如何將索引降至最低。
新建一個表:
(
i int primary key,
xx varchar(200) not null
)
加入數據:
set @x = 0while @x <1000
begin
insert into t3 values (@x,'qweasdqweasdqweasdqweqweasdqwe')
set @x = @x+1
end
執行動態管理視圖:
可以看到:

index_id為0表示這個是堆,平均的碎片有33%
現在執行幾個可以減少碎片的方法都不管用,不能減少碎片。
包括:
alter index PK__t3__0EA330E9 on t3
rebuild
dbcc dbreindex ('t3')
后來我覺得是因為數據太少了,導致頁也很少,數據庫可能存在某種智能,判斷是否值得去做重建索引的工作,所以加大的數據量:
set @x = 1000
while @x <10000
begin
insert into t3 values (@x,'qweasdqweasdqweasdqweqweasdqwe')
set @x = @x+1
end
再執行語句:
alter index t3index on t3
rebuild
顯示出來了!
結論:
SQL Server在執行相關的操作的時候都會智能去判斷是否值得去做,比如在頁面數太小的情況下可以不去重建索引,rebuild reindex 。類似的,在SQL Server 2005 里面也多了許多智能的判斷來保證一個完整龐大而又不失智能的設計,
比如:
生成查詢計劃的閥值
緩存機制,緩存的篩選,LRU算法
預讀機制
checkpoint減少回滾距離
智能join判斷
重編譯
了解SQL Server這種類似的軟件產品能夠為我們在設計產品的時候提供更多的思路想法,即使你了解上面的東西對你的SQL開發也不會有太多幫助。
另外附上幾種方式的區別:
reindex是比較好的選擇,速度快,但是他不能在線操作
INDEXDEFRAG 比較慢,但是可以在線操作
rebuild建議在碎片較少時采用。
附上微軟的重建索引腳本,從里面也可以看出微軟根據碎片大小推薦的方式,不過這個要隨每個不同的數據庫而定。-- ensure a USE <databasename> statement has been executed first.
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);
-- 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.
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 (DB_ID(), 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
BOL的推薦:
| avg_fragmentation_in_percent 值 | 修復語句 |
|---|---|
> 5% 且 < = 30% | ALTER INDEX REORGANIZE |
> 30% | ALTER INDEX REBUILD WITH (ONLINE = ON)* |
小于5沒必要重建,所以上面的SQL語句還是有得商量的地方。
分享:解析Sqlserver常用函數在操作SQLServer的時候, 很多時候記不住具體的函數如何使用, 查找聯機幫助還是嫌麻煩, 且有很多時候例子也不好懂, 下面對每個常用的函數用用例子說明,一目了然,你自己在數據庫中執行一下,結果就知道什么回事了 --字符串功能 --substring print substring('ia
- sql 語句練習與答案
- 深入C++ string.find()函數的用法總結
- SQL Server中刪除重復數據的幾個方法
- sql刪除重復數據的詳細方法
- SQL SERVER 2000安裝教程圖文詳解
- 使用sql server management studio 2008 無法查看數據庫,提示 無法為該請求檢索數據 錯誤916解決方法
- SQLServer日志清空語句(sql2000,sql2005,sql2008)
- Sql Server 2008完全卸載方法(其他版本類似)
- sql server 2008 不允許保存更改,您所做的更改要求刪除并重新創建以下表
- SQL Server 2008 清空刪除日志文件(瞬間日志變幾M)
- Win7系統安裝MySQL5.5.21圖解教程
- 將DataTable作為存儲過程參數的用法實例詳解
- 相關鏈接:
- 教程說明:
Mssql數據庫教程-怎樣將索引碎片數量降至最低
。