以下是sp_spaceused和sp_MSforeachtable具体的使用示例:
exec sp_spaceused '表名' (查询表所占空间)
exec sp_spaceused '表名', true (更新表的空间大小,准确的表空大小)
exec sp_spaceused (数据库大小查询)
exec sp_MSforeachtable "exec sp_spaceused '?'" (所有用户表空间表小,SQL统计数据,,大量事务操作后可能不准)
exec sp_MSforeachtable "exec sp_spaceused '?',true" (所有用户表空间表小,大数据库慎用)
====================详细版============================
做一个项目,第一件事情就是问:“这个数据库多大?”
下面是统计数据库数据量大小的方法
通常我们会使用命令: "sp_helpdb @dbname"
例如,查询数据库"testdb3"的使用量
exec sp_helpdb testdb3
"sp_helpdb"是最常用的命令,
但是注意:该命令显示的数据库大小"db_size"并不是指现存有效数据的大小,而是指:数据库物理文件 “数据文件大小 + 日志文件大小”的总和
例如上例中,数据库"testdb3"对应的数据文件和日志文件:
218.112 + 916.352 = 1107.88MB
数据库创始之初,数据文件和日志文件的初始大小都是默认的2M或3M
当插入数据后,数据文件和日志文件的大小会随着数据量的增长而增长
但是当删除数据的时候,会发生什么情况呢?
数据文件、日志文件会变小么?不会的,还是保持原来的大小
怎样获取有效数据的大小?
答案是使用"sp_spaceused"存储过程分别统计每张表的数据量
1) 统计单个表的使用空间
exec sp_spaceused 'dbo.t1'
2) 统计每个表的使用空间
exec sp_MSforeachtable "exec sp_spaceused '?'"