查看MSSQL数据库每个表占用的空间大小
广告投放★自助友情CMS落伍广告联盟晒乐广告联盟脉动广告联盟品味广告联盟
广告位可自定样式联系QQ:4285248个文字广告月20元广告联系QQ:428524广告位可自定样式
8个文字广告月20元黄金广告位每月20元广告位可自定样式联系QQ:428524广告位可自定样式
左旋肉碱、全国包邮
买二送一、无效退款

文章浏览→编程相关Mssql→查看MSSQL数据库每个表占用的空间大小

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

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


我在工作中碰到了一些问题,需要查看数据库表的大小,查询SQLServer联机从书得到如下语句:
sp_spaceused显示行数、保留的磁盘空间以及当前数据库中的表所使用的磁盘空间,或显示由整个数据库保留和使用的磁盘空间。
语法sp_spaceused [[@objname =] 'objname']
   [,[@updateusage =] 'updateusage']
参数[@objname =] 'objname'
是为其请求空间使用信息(保留和已分配的空间)的表名。objname 的数据类型是 nvarchar(776),默认设置为NULL。
[@updateusage =] 'updateusage'
表示应在数据库内(未指定 objname 时)还是在特定的对象上(指定 objname 时)运行DBCCUPDATEUSAGE。值可以是 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/1024free,
rows,* from sysindexes  where indid=1 order byreserved desc

第四种方法:^_^是我自己发现的.

  CREATE PROCEDURE get_tableinfoAS
  
  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 bycast(left(ltrim(rtrim(reserved)) , len(ltrim(rtrim(reserved)))-2)as int) desc

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

所属分类:编程相关Mssql    作者:新浪博客    时间:2010-4-24 12:21:00

文章导航