随笔 - 27  文章 - 0  评论 - 17  阅读 - 65297 

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

 

posted on   Jerryz  阅读(295)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
Top
收藏
关注
评论
点击右上角即可分享
微信分享提示