quinta-feira, 11 de agosto de 2011

Limpar Transaction Log no SQLServer 2008

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE PROCEDURE [dbo].[function_clean_transaction_log]
AS
BEGIN
declare @dbstring varchar(300)
select @dbstring = DB_NAME()
declare @sql varchar(500)

print 'Iniciando Deleção do Transaction Log (2 steps)...'
set @sql = 'ALTER DATABASE ['+@dbstring+'] SET RECOVERY SIMPLE'
exec (@sql)
DBCC SHRINKDATABASE (@dbstring, NOTRUNCATE) -- 1st step
DBCC SHRINKDATABASE (@dbstring, TRUNCATEONLY) -- 2nd step
set @sql = 'ALTER DATABASE ['+@dbstring+'] SET RECOVERY FULL'
exec (@sql)
print 'Deleção do Transaction Log Terminada.'
END

Limpar Transaction Log no SQLServer 2000/2005

CREATE PROCEDURE [dbo].[function_clean_transaction_log]
AS
BEGIN
declare @dbstring varchar(300)
select @dbstring = DB_NAME()
print 'Iniciando Deleção do Transaction Log...'
BACKUP LOG @dbstring WITH TRUNCATE_ONLY
DBCC SHRINKDATABASE (@dbstring)
print 'Deleção do Transaction Log Terminada.'
END
GO

Reconstruir Indices no SQL Server 2008

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE PROCEDURE [dbo].[function_clean_rebuild_indexes]
AS
BEGIN
-- FILLFACTOR 90
declare @TableName varchar(255)
declare @sql nvarchar(500)
declare @fillfactor int, @tot float, @now float
SET @fillfactor = 90

set @tot =
(select count(OBJECT_SCHEMA_NAME([object_id])+'.'+name) AS TableName
from sys.tables)
declare TableCursor cursor for
select OBJECT_SCHEMA_NAME([object_id])+'.'+name AS TableName
from sys.tables
order by 1

open TableCursor
fetch next from TableCursor into @TableName
print 'Iniciando ALTER INDEX ALL (FILL FACTOR '+cast(@fillfactor as varchar(10))+')...'

set @now = 0
while @@FETCH_STATUS = 0
begin
set @now = @now + 1
print 'Reindexando tabela ' + upper(@TableName) + ' ( '+cast(@now as varchar(10))+'/'+cast(@tot as varchar(10))+' - '+cast(round(@now * 100 / @tot, 2) as varchar(20))+'% ) ...'
SET @sql = 'ALTER INDEX ALL ON ' + @TableName + ' REBUILD WITH (FILLFACTOR = ' + CONVERT(VARCHAR(3),@fillfactor) + ')'
exec(@sql)
fetch next from TableCursor into @TableName
end
close TableCursor
deallocate TableCursor
print 'Reconstrução dos Índices Terminada.'
END

Reconstruir Indices no SQL Server 2000/2005

CREATE PROCEDURE [dbo].[function_clean_rebuild_indexes]
AS
BEGIN
SET ARITHABORT ON
SET QUOTED_IDENTIFIER ON

declare @tabname sysname
declare @dbstring varchar(300)
declare @exec_string varchar(300)

declare tabDBCC cursor for select table_name from information_schema.tables where table_type = 'base table'

open tabDBCC
fetch next from tabDBCC into @tabname

select @dbstring = DB_NAME()
print 'Iniciando DBCC DBREINDEX para a base ' + upper(@dbstring) + '...'

while (@@fetch_status = 0)
begin
print 'Reindexando tabela ' + upper(@tabname)
select @exec_string = 'dbcc dbreindex ([' + @tabname + '])'
exec(@exec_string)
fetch next from tabDBCC into @tabname
end

close tabDBCC
deallocate tabDBCC
print 'Reconstrução dos Índices Terminada.'
END
GO

terça-feira, 6 de novembro de 2007

Início...

Olá... sinceramente n estou com muito tempo no momento, mas pretendo sim postar algumas coisas aki... como artigos e idéias mais voltadas à área de tecnologia mesmo...

t+