Cómo desfragmentar bases de datos Windows SharePoint Services 3.0 y bases de datos SharePoint Server 2007

Ver los productos a los que se aplica este artículo

En este artículo se describe cómo desfragmentar las bases de datos siguientes Microsoft Windows SharePoint Services 3.0 y las bases de datos Microsoft Office SharePoint Server 2007:

• Base de datos de búsqueda

• Base de datos de perfiles

• Base de datos de contenido

Más información

La extensión de la fragmentación de índice de Microsoft SQL Server determina si una base de datos fragmentada será desfragmentada por un proceso de desfragmentación con conexión o un proceso de desfragmentación sin conexión. En desfragmentación con conexión SQL Server defragmenta páginas de hoja con conexión, no las páginas bloqueadas. En desfragmentación sin conexión, se desfragmentan las páginas bloqueadas y todas las páginas de hoja.
El archivo siguiente de comandos de SQL Server mide el nivel de fragmentación y actúa desfragmentación sin conexión o desfragmentación con conexión de modo igual si es necesario.
En la secuencia siguiente de comandos, el nivel de fragmentación se define como el número de bloques que son lógicamente lineales y físicamente no lineales. Si el nivel de desfragmentación es menos 10 por ciento, la desfragmentación no ocurre. Si el nivel de fragmentación está de 10 por ciento a 90 por ciento, se produce desfragmentación con conexión. Si el nivel de fragmentación es más de 90 por ciento, se produce desfragmentación sin conexión.

Importante Puede consultar también las normas Support especificadas en el artículo de Microsoft Knowledge Base siguiente:

841057 (http://support.microsoft.com/kb/841057/) Compatibilidad de cambios a las bases de datos utilizadas por productos de servidor de Office y Windows SharePoint Services

Nota Se recomienda que aloje las bases de datos SharePoint Server 2007 en un equipo que ejecuta SQL Server 2005. Supervise el nivel de fragmentación y después de ejecutar esta secuencia de comandos, prográmelo para que se ejecuten las secuencias de comandos diario, semanal, mensual, tan adecuado para su situación.

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
IF EXISTS (SELECT * FROM sysobjects WHERE type = 'P' AND name = 'proc_DefragIndexes')
	BEGIN
		DROP  Procedure  dbo.proc_DefragIndexes
	END

GO

-- =============================================
-- This stored procedure checks all indexes in the current
-- database and performs either offline or online defragmentation
-- according to the specified thresholds.
-- The stored procedure also updates statistics for indexes in which the last update
-- time is older than the specified threshold.
-- Parameters:
--	@onlineDefragThreshold specifies minimum percentage of fragmentation 
--	to perform online defragmentation (default 10%).
--	@offlineDefragThreshold specifies minimum percentage of fragmentation 
--	to perform offline defragmentation (default 90%).
--	@updateStatsThreshold specifies the number of days since the last statistics update
--	which should trigger updating statistics (default 7 days).
-- =============================================
CREATE PROCEDURE dbo.proc_DefragIndexes 
(
	@onlineDefragThreshold float = 10.0,
	@offlineDefragThreshold float = 90.0,
	@updateStatsThreshold int = 7
)
	
AS
BEGIN
	set nocount on
	DECLARE @objectid int
	DECLARE @indexid int
	DECLARE @frag float
	DECLARE @command varchar(8000)
	DECLARE @schemaname sysname
	DECLARE @objectname sysname
	DECLARE @indexname sysname

	declare @AllIndexes table (objectid int, indexid int, fragmentation float)

	declare @currentDdbId int
	select @currentDdbId = DB_ID()
	
	insert into @AllIndexes
	SELECT 
		object_id, index_id, avg_fragmentation_in_percent 
	FROM sys.dm_db_index_physical_stats (@currentDdbId, NULL, NULL , NULL, 'LIMITED')
	WHERE index_id > 0

	DECLARE indexesToDefrag CURSOR FOR SELECT * FROM @AllIndexes

	OPEN indexesToDefrag;

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

	WHILE @@FETCH_STATUS = 0
		BEGIN

		SELECT @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

		IF @frag > @onlineDefragThreshold
		BEGIN 
			IF @frag < @offlineDefragThreshold
				BEGIN;
					SELECT @command = 'ALTER INDEX ' + @indexname + ' ON ' + @schemaname + '.' + object_name(@objectid) + ' REORGANIZE'
					EXEC (@command)
				END;

			IF @frag >= @offlineDefragThreshold
				BEGIN;
					SELECT @command = 'ALTER INDEX ' + @indexname +' ON ' + @schemaname + '.' + object_name(@objectid) + ' REBUILD'
					EXEC (@command)
				END;
			PRINT 'Executed ' + @command
		END

		IF STATS_DATE(@objectid, @indexid) < DATEADD(dd, -@updateStatsThreshold, getdate())
		BEGIN
			SELECT @command = 'UPDATE STATISTICS ' + @schemaname + '.' + object_name(@objectid) + ' ' + @indexname +' WITH RESAMPLE'
			EXEC (@command)

			PRINT 'Executed ' + @command
		END

		FETCH NEXT FROM indexesToDefrag INTO @objectid, @indexid, @frag

	END

	CLOSE indexesToDefrag;
	DEALLOCATE indexesToDefrag;
END
GO

Para obtener más información, haga clic en el número de artículo siguiente para verlo en Microsoft Knowledge Base

932744 (http://support.microsoft.com/kb/932744/) Información sobre el Asistente Plan de Mantenimiento en SQL Server 2005 y tareas que pueden realizar los administradores en bases de datos de SharePoint

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *