日韩天天综合网_野战两个奶头被亲到高潮_亚洲日韩欧美精品综合_av女人天堂污污污_视频一区**字幕无弹窗_国产亚洲欧美小视频_国内性爱精品在线免费视频_国产一级电影在线播放_日韩欧美内地福利_亚洲一二三不卡片区

怎樣將索引碎片數(shù)量降至最低_Mssql數(shù)據(jù)庫教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:SQL Server中, DateTime (日期)型操作的 SQL語法
這兩天操作SQL Server的數(shù)據(jù),需求是將一個日期類型字段的時、分、秒去處,即 ‘2007-11-07 16:41:35.033’ 改為‘2007-11-07 00:00:00‘,所以查詢了一下網(wǎng)上對DateTime類型操作的SQL語法,發(fā)現(xiàn)實現(xiàn)這個功能很簡單。 update YourTable set YourDateColumn

索引碎片能增大索引樹的大小,增加不必要的IO,所以每隔一段時間對索引碎片進(jìn)行檢查時很有必要的。
下面一個示例一起來分析如何將索引降至最低。

新建一個表:
create table t3
(
i int primary key,
xx varchar(200) not null
)

加入數(shù)據(jù):
declare @x int
set @x = 0while @x <1000
begin
insert into t3 values (@x,'qweasdqweasdqweasdqweqweasdqwe')
set @x = @x+1
end

執(zhí)行動態(tài)管理視圖:
SELECT index_id,index_type_desc,avg_fragmentation_in_percent,page_count FROM sys.dm_db_index_physical_stats(db_id(), OBJECT_ID('t3'), NULL, NULL , 'LIMITED');
 

可以看到:


index_id為0表示這個是堆,平均的碎片有33%

現(xiàn)在執(zhí)行幾個可以減少碎片的方法都不管用,不能減少碎片。
包括:
DBCC INDEXDEFRAG (test, 'dbo.t3', PK__t3__0EA330E9)

alter index PK__t3__0EA330E9 on t3
rebuild

dbcc dbreindex ('t3')
 
這幾個方法還有刪除重建索引,都不能減少碎片數(shù)量。

后來我覺得是因為數(shù)據(jù)太少了,導(dǎo)致頁也很少,數(shù)據(jù)庫可能存在某種智能,判斷是否值得去做重建索引的工作,所以加大的數(shù)據(jù)量:
declare @x int
set @x = 1000
while @x <10000
begin
insert into t3 values (@x,'qweasdqweasdqweasdqweqweasdqwe')
set @x = @x+1
end

再執(zhí)行語句:
SELECT index_id,index_type_desc,avg_fragmentation_in_percent,page_count FROM sys.dm_db_index_physical_stats(db_id(), OBJECT_ID('t3'), NULL, NULL , 'LIMITED');

alter index t3index on t3
rebuild



顯示出來了!


結(jié)論:
SQL Server在執(zhí)行相關(guān)的操作的時候都會智能去判斷是否值得去做,比如在頁面數(shù)太小的情況下可以不去重建索引,rebuild reindex 。類似的,在SQL Server 2005 里面也多了許多智能的判斷來保證一個完整龐大而又不失智能的設(shè)計,
比如:
生成查詢計劃的閥值
緩存機(jī)制,緩存的篩選,LRU算法
預(yù)讀機(jī)制
checkpoint減少回滾距離
智能join判斷
重編譯

了解SQL Server這種類似的軟件產(chǎn)品能夠為我們在設(shè)計產(chǎn)品的時候提供更多的思路想法,即使你了解上面的東西對你的SQL開發(fā)也不會有太多幫助。

另外附上幾種方式的區(qū)別:
reindex是比較好的選擇,速度快,但是他不能在線操作
INDEXDEFRAG 比較慢,但是可以在線操作
rebuild建議在碎片較少時采用。

附上微軟的重建索引腳本,從里面也可以看出微軟根據(jù)碎片大小推薦的方式,不過這個要隨每個不同的數(shù)據(jù)庫而定。-- 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修復(fù)語句

> 5% 且 < = 30%

ALTER INDEX REORGANIZE

> 30%

ALTER INDEX REBUILD WITH (ONLINE = ON)*

小于5沒必要重建,所以上面的SQL語句還是有得商量的地方。

分享:解析Sqlserver常用函數(shù)
在操作SQLServer的時候, 很多時候記不住具體的函數(shù)如何使用, 查找聯(lián)機(jī)幫助還是嫌麻煩, 且有很多時候例子也不好懂, 下面對每個常用的函數(shù)用用例子說明,一目了然,你自己在數(shù)據(jù)庫中執(zhí)行一下,結(jié)果就知道什么回事了 --字符串功能 --substring print substring('ia

來源:模板無憂//所屬分類:Mssql數(shù)據(jù)庫教程/更新時間:2010-05-27
相關(guān)Mssql數(shù)據(jù)庫教程