您的位置:首页 > 数据库

查看MSSQL数据库每个表占用的空间大小

2012-05-21 20:02 489 查看
查看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')
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: