查看SQLServer2008數據表佔用硬盤的空間大小

sp_spaceused
顯示行數、保留的磁盤空間以及當前數據庫中的表所使用的磁盤空間,或顯示由整個數據庫保留和使用的磁盤空間。
語法
sp_spaceused [[@objname =] 'objname']
[,[@updateusage =] 'updateusage']
參數
[@objname =] 'objname'
是爲其請求空間使用信息(保留和已分配的空間)的表名。objname 的數據類型是 nvarchar(776),默認設置爲 NULL。
[@updateusage =] 'updateusage'
表示應在數據庫內(未指定 objname 時)還是在特定的對象上(指定 objname 時)運行 DBCC UPDATEUSAGE。值可以是 true 或 false。updateusage 的數據類型是 varchar(5),默認設置爲 FALSE。
返回代碼值
0(成功)或 1(失敗)
示例
A. 有關表的空間信息
下例報告爲 titles 表分配(保留)的空間量、數據使用的空間量、索引使用的空間量以及由數據庫對象保留的未用空間量。
USE pubs
EXEC sp_spaceused 'titles'
B. 有關整個數據庫的已更新空間信息
下例概括當前數據庫使用的空間並使用可選參數 @updateusage。
USE pubs
sp_spaceused @updateusage = 'TRUE'
不過此方法,只能查看一個表的大小,一個數據庫中一般會有多個表,如何一次性查看某數據庫的所有表大小呢?
create table test(
name varchar(50),
rows int,
reserved varchar(20),
data varchar(20),
index_size varchar(20),
unused varchar(20)
)
insert into test
exec sp_MSforeachtable "exec sp_spaceused '?'"
select * from test order by cast(replace(reserved,'KB','') as int) desc


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章