SQL查询某数据库各表占用磁盘空间和收缩数据库MDF文件

本文介绍了一种查询数据库中各表占用空间的方法,并提供了一个实用的SQL脚本。通过执行此脚本可以了解到每张表的数据量及索引大小等信息。此外还提供了数据库收缩的方法,帮助减少数据库文件大小。

 

ContractedBlock.gifExpandedBlockStart.gif查某库多数表占用空间

--查数据库中多数表占用的空间

CREATE TABLE TMP
(name varchar(50),
rows int,
reserved varchar(50),
data varchar(50),
index_size varchar(50),
unused varchar(50))
GO

INSERT INTO tmp (name,rows,reserved,data,index_size,unused)
EXEC sp_msforeachTable @Command1="sp_spaceused '?'"
SELECT *,CONVERT(int, replace(data,' KB','')) as tt FROM tmp ORDER BY tt DESC
DROP TABLE tmp


GO


--收缩可让数据库大小减小很多特别是MDF文件
ALTER DATABASE DBname 
Set  RECOVERY SIMPLE 
Go 

DBCC SHRINKDATABASE  (DBname) 
Go 

ALTER DATABASE DBname 
Set  RECOVERY  FULL 
Go 

 

转载于:https://www.cnblogs.com/hanguoji/archive/2009/06/09/1499880.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值