数据库备份时,数据过多,批量脚本整理,查询表所占空间
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
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
相关文章推荐
- 使用一个T-SQL语句批量查询数据表占用空间及其行数
- Oracle数据库案例整理-执行Oracle脚本失败或异常-表空间限额用尽导致插入数据失败
- SQL2008数据表空间大小查询脚本
- SQL2008数据表空间大小查询脚本
- 使用一个T-SQL语句批量查询数据表占用空间及其行数
- 利用游标批量清空数据同时批量查询数据空间和条数
- 使用一个T-SQL语句批量查询数据表占用空间及其行数
- 使用一个T-SQL语句批量查询数据表占用空间及其行数
- mysql高级----查询截取分析(二):批量插入数据脚本、用show profile分析sql、全局查询日志
- Shell脚本:向磁盘中批量写入数据
- MongoDB的地埋空间数据存储、空间索引以及空间查询
- 大量包含Insert语句的脚本文件批量执行导入数据
- 学习随笔(一):Shell脚本批量导入数据到Oracle数据库
- 查询表空间剩余大小脚本
- 常用工具之 vb转化C# 数据连接串 正则表达式查询 源码世界 脚本字典
- Oracle查询表空间的使用情况和数据文件是否拓展及剩余可拓展大小
- (转)分享一个SQLSERVER脚本(计算数据库中各个表的数据量和每行记录所占用空间)
- 使用游标批量获取数据提高查询性能
- 基于Geomesa服务查询轨迹数据无法根据空间和时间范围进行结果查询
- 基于Python脚本和聚合数据实现手机号码归属地信息查询