Bilgi Bankası Makalelerinde Ara
SQL INDEX BAKIM
CREATE FUNCTION dbo.index_name (@object_id int, @index_id int)
RETURNS sysname
AS
BEGIN
RETURN(SELECT name FROM sys.indexes WHERE
object_id = @object_id and index_id = @index_id)
END;
GO
-- ile öncelikle fonksiyonumuzu yaratıyoruz. Sonra da;
SELECT
OBJECT_NAME(object_id) AS tabloadi
,dbo.index_name(object_id, index_id) AS indexadi
,avg_fragmentation_in_percent
FROM sys.dm_db_index_physical_stats(DB_ID(), NULL, NULL, NULL, NULL)
WHERE avg_fragmentation_in_percent > 10
AND index_type_desc IN('CLUSTERED INDEX', 'NONCLUSTERED INDEX')
-- ile hangi tablonun hangi index verisi ne oranda bozulmuş görebiliyoruz.
--Aşağıdaki kod ile tüm veritabanlarında yer alan tüm index yapıları kontrol ediliyor ve fragmantasyon yapılıyor.
DECLARE @Database VARCHAR(255)
DECLARE @Table VARCHAR(255)
DECLARE @cmd NVARCHAR(500)
DECLARE @fillfactor INT
SET @fillfactor = 90
DECLARE DatabaseCursor CURSOR FOR
SELECT name FROM MASTER.dbo.sysdatabases
WHERE name IN ('DATABASEADI')
ORDER BY 1
OPEN DatabaseCursor
FETCH NEXT FROM DatabaseCursor INTO @Database
WHILE @@FETCH_STATUS = 0
BEGIN
SET @cmd = 'DECLARE TableCursor CURSOR FOR SELECT ''['' + table_catalog + ''].['' + table_schema + ''].['' +
table_name + '']'' as tableName FROM ' + @Database + '.INFORMATION_SCHEMA.TABLES WHERE table_type = ''BASE TABLE'''
-- create table cursor
EXEC (@cmd)
OPEN TableCursor
FETCH NEXT FROM TableCursor INTO @Table
WHILE @@FETCH_STATUS = 0
BEGIN
IF (@@MICROSOFTVERSION / POWER(2, 24)>= 9)
BEGIN
-- SQL 2005 yada sonrası
SET @cmd = 'ALTER INDEX ALL ON ' + @Table + ' REBUILD WITH (FILLFACTOR = ' + CONVERT(VARCHAR(3),@fillfactor) + ')'
EXEC (@cmd)
END
ELSE
BEGIN
-- SQL 2000 komutu
DBCC DBREINDEX(@Table,' ',@fillfactor)
END
FETCH NEXT FROM TableCursor INTO @Table
END
CLOSE TableCursor
DEALLOCATE TableCursor
FETCH NEXT FROM DatabaseCursor INTO @Database
END
CLOSE DatabaseCursor
DEALLOCATE DatabaseCursor
Bu makaleyi yararlı buldunuz mu?
İlişkili Makaleler
-
SQL Kolon Karşılaştırma
DECLARE @tablename varchar(100) SET @tablename = N'myTable' SELECT clmns.name AS [Name], usrt.na... -
İki Farklı Server Aktarım
INSERT INTO OPENDATASOURCE('SQLNCLI','Data source=192.168.1.6;initial catalog=NETSIS;persist securit... -
could not continue scan with nolock due to data movement
Data s*çmış demektir. Korkma hallolur. Çözümü ise Şöyledir; 1- ... -
DBCC CHECKDB ILE VERTABANI KONTROLU
DBCC CHECKDBParametre olarak verilen veritabanının bütünlük kontrolleri yapılır. Veri... -
Sql Mail Gönderme
DECLARE @email nvarchar(250) DECLARE @GECIKMISBAKIYE VARCHAR(20) DECLARE @GUN VA...