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 '?'"
第二种方法(较复杂,但看的比较清楚,原作者不详):
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