SQL Server - Reducir o optimar espacio NO USADO en las BDs SQL

 
Vista:

Reducir o optimar espacio NO USADO en las BDs SQL

Publicado por Humberto Neira (2 intervenciones) el 26/01/2006 20:58:26
Estimados,

El siguiente Store Procedure (ver más abajo), permite revisar el espacio ocupado, reservado y libre para cada una de las tablas de una BD.

Mi pregunta es:
*** Existe algún utilitario, comando SQL, store procedure de sistema que permita compactar o reducir el espacio no ocupado para asi reducir el espacio total de la Base de Datos.

gracias por la ayuda.

saludos
Valora esta pregunta
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder

RE:Reducir o optimar espacio NO USADO en las BDs S

Publicado por Humberto Neira (2 intervenciones) el 26/01/2006 21:03:26
Sorry aqui va el Store Procedure:

if exists (select * from sysobjects where id = object_id('dbo.p_sizetables') and sysstat & 0xf = 4)
drop procedure dbo.p_sizetables
GO
create procedure dbo.p_sizetables
as
Begin transaction
/**************Procedimiento creado por KM para ver el tamaño de las tablas de una base de datos*/
SET NOCOUNT ON
declare @nombre_tabla varchar(100)
declare @propietario varchar(40)
declare @uid int
declare @nombre_completo varchar(150)
declare @nombre_db varchar(256)

create table #resultados
(nombre varchar(50),
filas decimal(12,0),
reservado varchar(40),
data varchar(40),
tamaño_indice varchar(20),
no_usado varchar(20))

declare tablas cursor
for select a.uid , propietario = left( b.name,40), tabla = a.name from sysobjects a, sysusers b
where type = 'U' and a.uid = b.uid order by tabla

select @nombre_db = db_name()

OPEN tablas
FETCH NEXT FROM tablas into @uid, @propietario, @nombre_tabla
WHILE @@FETCH_STATUS = 0
BEGIN
if @uid = 1
begin
insert #resultados
exec sp_spaceused @nombre_tabla
end
else
begin
SET @nombre_completo = rtrim(ltrim(@nombre_db))+'.' + ltrim(rtrim(@propietario)) +'.'+ @nombre_tabla
insert #resultados
exec sp_spaceused @nombre_completo
end
FETCH NEXT FROM tablas INTO @uid, @propietario, @nombre_tabla
END

CLOSE tablas
DEALLOCATE tablas

select * from #resultados
order by filas desc


Commit Transaction

exec p_sizetables
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar