您的位置:首页 > 数据库

数据库备份时,数据过多,批量脚本整理,查询表所占空间

2013-09-25 14:15 344 查看
--找出表占据空间最大的
create table #t(name varchar(255), rows bigint, reserved varchar(20), data varchar(20), index_size varchar(20), unused varchar(20))
exec sp_MSforeachtable "insert into #t exec sp_spaceused '?'"
select * from #t order by rows desc;
select SUM(Cast(REPLACE(data,' KB','') as int)) as 总花费容量 from #t;
drop table #t

--调用删除存储过程
select top 1* from HR_StaffAppraise;
select COUNT(*) from HR_StaffAppraise;
exec pro_DeleteRubish 'HR_StaffAppraise','ApprProposalId','staffid','apprperiodvalue';

--存储过程原型 分组后保留该组至少一条数据
delete from @tableName where @idName not in
(
select @idName from (
select @idName,row_number() over(partition by @groupName order by @orderName desc) rn
from @tableName
) t where t.rn <=1
)

--存储过程
create PROCEDURE pro_DeleteRubish
@tableName nvarchar(200),
@idName nvarchar(200),
@groupName nvarchar(200),
@orderName nvarchar(200)
AS
BEGIN
declare @sql nvarchar(1000)
set @sql='delete from '+ @tableName+' where '+@idName+' not in(select '+@idName+' from (select '+@idName+',row_number() over(partition by '+@groupName+' order by '+@orderName+' desc) rn
from '+@tableName+'
) t where t.rn <=1
)';
print @sql
exec (@sql)
END
GO
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: