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

--找出表占据空间最大的
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

 

转载于:https://www.cnblogs.com/shenqiboy/p/3338661.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值