查看MSSQL數據庫每個表佔用的空間大小
我在工作中碰到了一些問題,需要查看數據庫表的大小,查詢SQL Server聯機從書得到如下語句:
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'
不過此方法,只能查看一個表的大小,一個數據庫中一般會有多個表,如何一次性查看某數據庫的所有表大小呢?
第一種方法(較簡單,看的有些吃力):
exec sp_MSforeachtable "exec sp_spaceused '?'"
第二種方法(較複雜,但看的比較清楚,原作者不詳):
其實只要使用系統內置的存儲過程sp_spaceused就可以得到表的相關信息
如:sp_spaceused 'tablename'
以下是爲了方便寫的一個存儲過程,目的是把當前的所有表的相關信息全部都保存在一個指定的表裏面
CREATE PROCEDURE get_tableinfo AS
if not exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[tablespaceinfo]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
create table tablespaceinfo --創建結果存儲表
(nameinfo varchar(50) ,
rowsinfo int , reserved varchar(20) ,
datainfo varchar(20) ,
index_size varchar(20) ,
unused varchar(20) )
delete from tablespaceinfo --清空數據表
declare @tablename varchar(255) --表名稱
declare @cmdsql varchar(500)
DECLARE Info_cursor CURSOR FOR
select o.name
from dbo.sysobjects o where OBJECTPROPERTY(o.id, N'IsTable') = 1
and o.name not like N'#%%' order by o.name
OPEN Info_cursor
FETCH NEXT FROM Info_cursor
INTO @tablename
WHILE @@FETCH_STATUS = 0
BEGIN
if exists (select * from dbo.sysobjects where id = object_id(@tablename) and OBJECTPROPERTY(id, N'IsUserTable') = 1)
execute sp_executesql
N'insert into tablespaceinfo exec sp_spaceused @tbname',
N'@tbname varchar(255)',
@tbname = @tablename
FETCH NEXT FROM Info_cursor
INTO @tablename
END
CLOSE Info_cursor
DEALLOCATE Info_cursor
GO
執行存儲過程
exec get_tableinfo
查詢運行該存儲過程後得到的結果
select *
from tablespaceinfo
order by cast(left(ltrim(rtrim(reserved)) , len(ltrim(rtrim(reserved)))-2) as int) desc
--itlearner注:顯示數據庫信息
sp_spaceused @updateusage = 'TRUE'
--itlearner注:顯示錶信息
第三種方法:
select object_name(id) tablename,8*reserved/1024reserved,rtrim(8*dpages/1024)+'Mb' used,8*(reserved-dpages)/1024unused,8*dpages/1024-rows/1024*minlen/1024 free,
rows,* from sysindexes where indid=1 order by reserved desc
第四種方法:^_^是我自己發現的.
CREATE PROCEDURE get_tableinfo AS
if not exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[tablespaceinfo]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
create table tablespaceinfo --創建結果存儲表
(nameinfo varchar(50) ,
rowsinfo int , reserved varchar(20) ,
datainfo varchar(20) ,
index_size varchar(20) ,
unused varchar(20) )
truncate table tablespaceinfo --清空數據表
--這裏.....關鍵部分.把存儲過程的結果放到一個表裏.
insert into tablespaceinfo exec sp_MSforeachtable "exec sp_spaceused '?'"
go
查詢運行該存儲過程後得到的結果
select * from tablespaceinfo order by cast(left(ltrim(rtrim(reserved)) , len(ltrim(rtrim(reserved)))-2) as int) desc
如果你細心觀察也會發現的.我的第四種方法是,總結了第一種和第二種辦法來使用的.
OTHER:
1 返回每個表大小信息
create table tmp (name varchar(50),rows int,reserved varchar(50),
data varchar(50),index_size varchar(50),unused varchar(50))
insert into tmp (name,rows,reserved,
data,index_size,unused) exec sp_msforeachTable @Command1="sp_spaceused '?'"--sp_spaceused 't_vehicle'
select * from tmp order by data desc
drop table tmp
2 獲取某個表的所有列信息
select * from syscolumns where id in (select id from sysobjects where name='ceforst')