需要查看数据库表的大小,查询SQL Server联机从书得到如下语句:

sp_spaceused

显示行数、保留的磁盘空间以及当前数据库中的表所使用的磁盘空间,或显示由整个数据库保留和使用的磁盘空间。

语法

sp_spaceused [[@objname =] 'objname']
    [,[@updateusage =] 'updateusage']

参数

[@objname =] 'objname'

是为其请求空间使用信息(保留和已分配的空间)的表名。objname 的数据类型是 nvarchar(776),默认设置为 NULL。

[@updateusage =] 'updateusage'

表示应在数据库内(未指定 objname 时)还是在特定的对象上(指定 objname 时)运行DBCC UPDATEUSAGE。值可以是 truefalseupdateusage 的数据类型是 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 '?'"

第二种方法(较复杂,但看的比较清楚,原作者不详):

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

--itlearner注:显示数据库信息
sp_spaceused @updateusage = 'TRUE'

--itlearner注:显示表信息
select *
from tablespaceinfo
order by cast(left(ltrim(rtrim(reserved)) , len(ltrim(rtrim(reserved)))-2) as int) desc

第三种方法:

select object_name(id) tablename,8*reserved/1024
reserved,rtrim(8*dpages/1024)+'Mb' used,8*(reserved-dpages)/1024
unused,8*dpages/1024-rows/1024*minlen/1024 free,
rows,* from sysindexes
where indid=1
order by reserved desc

最新文章

  1. EF 连接MySQL 数据库  保存中文数据后乱码问题
  2. 解决虚拟机 MAC10.9 不能设置1366*768分辨率问题
  3. redmine一键安装
  4. javaScript初学者易错点
  5. android滑动删除的多种实现方式(一)
  6. Android学习----打印日志Log
  7. cenos 安装 phpredis 扩展
  8. cocos2d-x-lua基础系列教程四(lua多继承)
  9. JavaScript 执行环境(执行上下文) 变量对象 作用域链 上下文 块级作用域 私有变量和特权方法
  10. idea+springmvc+spring+mybatis+maven整合返回json数据webapi
  11. Android计时器实现
  12. 集美大学网络1413第十五次作业成绩(团队十) -- 项目复审与事后分析(Beta版本)
  13. Shell编程之文本处理
  14. Vue 组件(component)之 精美的日历
  15. SLAM入门之视觉里程计(3):两视图对极约束 基础矩阵
  16. STL之permutation/ equal_range/ binary_range学习
  17. ubuntu下配置反向代理
  18. pandas 处理文本数据
  19. CSS背景渐变支持transition过渡效果
  20. linux操作系统3 vi编辑器

热门文章

  1. DataBinder.Eval的正确使用
  2. LG4169 [Violet]天使玩偶/SJY摆棋子
  3. webpack libray 参考例子
  4. VS2010单元测试入门实践教程
  5. Bootstrap组件福利篇:十二款好用的组件推荐
  6. U盘永久系统-centos
  7. C++代码规范之命名
  8. ASP.NET Redis 开发 入门
  9. Log4j.xml配置(rolling示例)
  10. 如何搭建struts2框架