如何才能快速知道数据库中每个表的大小?
2005-01-22 10:56
866 查看
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(失败)
结果集
如果省略 objname,则返回两个结果集。
列名 数据类型 描述
database_name varchar(18) 当前数据库的名称。
database_size varchar(18) 当前数据库的大小。
unallocated space varchar(18) 数据库的未分配空间。
列名 数据类型 描述
reserved varchar(18) 保留的空间总量。
Data varchar(18) 数据使用的空间总量。
index_size varchar(18) 索引使用的空间。
Unused varchar(18) 未用的空间量。
如果指定参数,则返回下面的结果集。
列名 数据类型 描述
Name nvarchar(20) 为其请求空间使用信息的表名。
Rows char(11) objname 表中现有的行数。
reserved varchar(18) 为 objname 表保留的空间总量。
Data varchar(18) objname 表中的数据所使用的空间量。
index_size varchar(18) objname 表中的索引所使用的空间量。
Unused varchar(18) objname 表中未用的空间量。
注释
sp_spaceused 计算数据和索引使用的磁盘空间量以及当前数据库中的表所使用的磁盘空间量。如果没有给定 objname,sp_spaceused 则报告整个当前数据库所使用的空间。
当指定 updateusage 时,Microsoft? SQL Server? 扫描数据库中的数据页,并就每个表使用的存储空间对 sysindexes 表作出任何必要的纠正。例如会出现这样一些情况:当除去索引后,表的 sysindexes 信息可能不是当前的。该进程在大表或数据库上可能要花一些时间运行。只有当怀疑所返回的值不正确,而且该进程对数据库中的其它用户或进程没有负面影响时,才应使用该进程。如果首选该进程,则可以单独运行 DBCC UPDATEUSAGE。
权限
执行权限默认授予 public 角色。
示例
A. 有关表的空间信息
下例报告为 titles 表分配(保留)的空间量、数据使用的空间量、索引使用的空间量以及由数据库对象保留的未用空间量。
USE pubs
EXEC sp_spaceused 'titles'
B. 有关整个数据库的已更新空间信息
下例概括当前数据库使用的空间并使用可选参数 @updateusage。
USE pubs
sp_spaceused @updateusage = 'TRUE'
显示行数、保留的磁盘空间以及当前数据库中的表所使用的磁盘空间,或显示由整个数据库保留和使用的磁盘空间。
语法
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(失败)
结果集
如果省略 objname,则返回两个结果集。
列名 数据类型 描述
database_name varchar(18) 当前数据库的名称。
database_size varchar(18) 当前数据库的大小。
unallocated space varchar(18) 数据库的未分配空间。
列名 数据类型 描述
reserved varchar(18) 保留的空间总量。
Data varchar(18) 数据使用的空间总量。
index_size varchar(18) 索引使用的空间。
Unused varchar(18) 未用的空间量。
如果指定参数,则返回下面的结果集。
列名 数据类型 描述
Name nvarchar(20) 为其请求空间使用信息的表名。
Rows char(11) objname 表中现有的行数。
reserved varchar(18) 为 objname 表保留的空间总量。
Data varchar(18) objname 表中的数据所使用的空间量。
index_size varchar(18) objname 表中的索引所使用的空间量。
Unused varchar(18) objname 表中未用的空间量。
注释
sp_spaceused 计算数据和索引使用的磁盘空间量以及当前数据库中的表所使用的磁盘空间量。如果没有给定 objname,sp_spaceused 则报告整个当前数据库所使用的空间。
当指定 updateusage 时,Microsoft? SQL Server? 扫描数据库中的数据页,并就每个表使用的存储空间对 sysindexes 表作出任何必要的纠正。例如会出现这样一些情况:当除去索引后,表的 sysindexes 信息可能不是当前的。该进程在大表或数据库上可能要花一些时间运行。只有当怀疑所返回的值不正确,而且该进程对数据库中的其它用户或进程没有负面影响时,才应使用该进程。如果首选该进程,则可以单独运行 DBCC UPDATEUSAGE。
权限
执行权限默认授予 public 角色。
示例
A. 有关表的空间信息
下例报告为 titles 表分配(保留)的空间量、数据使用的空间量、索引使用的空间量以及由数据库对象保留的未用空间量。
USE pubs
EXEC sp_spaceused 'titles'
B. 有关整个数据库的已更新空间信息
下例概括当前数据库使用的空间并使用可选参数 @updateusage。
USE pubs
sp_spaceused @updateusage = 'TRUE'
相关文章推荐
- 如何才能快速知道中每个表的大小?
- 如何知道PostgreSQL数据库下每个数据库所对应的目录
- 如何才能过快速了解成品软件的数据库结构
- 【探讨】C++ delete[] 是如何知道数组大小的
- 如何估算PGA,SGA的大小,配置数据库服务器的内存
- 如何快速地比较两数据库结构的差异
- 如何快速更新数据库中的百万条数据
- 如何快速查看oracle服务名连接的数据库的信息
- sql 查询数据库中每个表的大小
- java web如何估算平均每个请求占用内存大小(转)
- 通过beego快速创建一个Restful风格API项目及API文档自动化 本文演示如何快速(一分钟内,不写一行代码)的根据数据库及表创建一个Restful风格的API项目,及提供便于在线测试API的界
- 如何快速的知道程序中输入的大段数据哪一行没有被正确执行或输出
- 拥有5星评级数据库表结构 如何才能更高效的使用?
- 查看 MySQL 数据库中每个表占用的空间大小
- SQLServer 如何知道连接某个数据库的人数
- MSSQL如何快速清除数据库日志-转,经实践有效
- 用代码如何知道当前正在使用的哪个数据库?
- 新站如何才能快速让搜索引擎收录
- oracle如何添加数据库表空间的大小
- 如何设置适合大小的stripe size对数据库?