--利用 Cursor 读取每一个 Table 的使用量
SET NOCOUNT ON
--避免数据不正确,先更新 sysindexes 内的数据
DECLARE @db VARCHAR(20)
SET @db=db_name()
DBCC UPDATEUSAGE(@db) WITH NO_INFOMSGS
GO
CREATE TABLE #tblSpace
(
数据表名称 varchar(50) null,
记录笔数 int null,
保留空间 varchar(15) null,
数据使用空间 varchar(15) null,
索引使用空间 varchar(15) null,
未使用空间 varchar(15) null
)
DECLARE @tblName VARCHAR(50)
DECLARE curTbls CURSOR FOR
SELECT name from sysobjects where xtype='U'
OPEN curTbls
FETCH NEXT FROM curTbls INTO @tblName
WHILE @@FETCH_STATUS=0
BEGIN
INSERT #tblSpace EXEC sp_spaceused @tblName
FETCH NEXT FROM curTbls INTO @tblName
END
CLOSE curTbls
DEALLOCATE curTbls
SELECT * FROM #tblSpace ORDER BY
CONVERT(INT,LEFT(保留空间,LEN(保留空间)-2)) DESC
DROP TABLE #tblSpace