`
zhangziyueup
  • 浏览: 1170576 次
文章分类
社区版块
存档分类
最新评论

如何获取SQL Server数据库里表的占用容量大小(转)

 
阅读更多
其实只要使用系统内置的存储过程sp_spaceused就可以得到表的相关信息

如:sp_spaceused 'tablename'

以下是为了方便写的一个存储过程,目的是把当前的所有表的相关信息全部都保存在一个指定的表里面

CREATEPROCEDUREget_tableinfoAS

ifnotexists(select*fromdbo.sysobjectswhereid=object_id(N'[dbo].[tablespaceinfo]')andOBJECTPROPERTY(id,N'IsUserTable')=1)
createtabletablespaceinfo--创建结果存储表
(nameinfovarchar(50),
rowsinfo
int,reservedvarchar(20),
datainfo
varchar(20),
index_size
varchar(20),
unused
varchar(20))


deletefromtablespaceinfo--清空数据表

declare@tablenamevarchar(255)--表名称

declare@cmdsqlvarchar(500)

DECLAREInfo_cursorCURSORFOR
selecto.name
fromdbo.sysobjectsowhereOBJECTPROPERTY(o.id,N'IsTable')=1
ando.namenotlikeN'#%%'orderbyo.name

OPENInfo_cursor

FETCHNEXTFROMInfo_cursor
INTO@tablename

WHILE@@FETCH_STATUS=0
BEGIN

ifexists(select*fromdbo.sysobjectswhereid=object_id(@tablename)andOBJECTPROPERTY(id,N'IsUserTable')=1)
executesp_executesql
N
'insertintotablespaceinfoexecsp_spaceused@tbname',
N
'@tbnamevarchar(255)',
@tbname=@tablename

FETCHNEXTFROMInfo_cursor
INTO@tablename
END

CLOSEInfo_cursor
DEALLOCATEInfo_cursor
GO
select *
from tablespaceinfo
order by cast(left(ltrim(rtrim(reserved)) , len(ltrim(rtrim(reserved)))-2) as int) desc
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics