SQL Server获取表的容量很简单!

数据库 SQL Server
以下的文章主要是介绍SQL Server获取表的占用容量大小的实际操作步骤,以下就是文章的主要内容的详细介绍,望你能有所收获。

以下的文章主要描述的是SQL Server获取表的占用容量大小的实际操作步骤,其实在实际操作中只要使用系统内置的存储过程sp_spaceused 就能轻松得到到表的相关信息如:sp_spaceused 'tablename'。

 

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

 

如:sp_spaceused 'tablename'

 

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

CREATEPROCEDUREget_tableinfoAS  
ifnotexists(select*fromdbo.sysobjectswhereid=object_id(N'[dbo].[tablespaceinfo]')andOBJECTPROPERTY(id,N'IsUserTable')=1)   
createtabletablespaceinfo--创建结果存储表   
(nameinfovarchar(50),   
rowsinfoint,reservedvarchar(20),   
datainfovarchar(20),   
index_sizevarchar(20),   
unusedvarchar(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   
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.

执行存储过程

exec get_tableinfo

查询运行该存储过程后得到的结果

select *   
from tablespaceinfo   
order by cast(left(ltrim(rtrim(reserved)) , len(ltrim(rtrim(reserved)))-2) as int) desc  
 
  • 1.
  • 2.
  • 3.
  • 4.

以上的相关内容就是对SQL Server获取表的占用容量大小的介绍,望你能有所收获。

【编辑推荐】

  1. SQL Server 2000的安全策略的正确打造
  2. SQL Server实例中对另个实例的调用
  3. SQL Server2000连接错误的缘由有哪些?
  4. SQL Server2000连接错误的原因描述
  5. SQL Server2000连接中出现错误的原因是什么?
责任编辑:佚名 来源: 清华大学出版社
相关推荐

2010-07-09 15:31:25

SQL Server

2010-07-19 08:36:56

SQL Server内

2010-06-17 17:11:03

SQL Server

2010-07-14 17:42:12

2010-07-15 17:57:48

SQL Server数

2010-06-17 14:05:11

SQL Server

2011-04-07 17:39:16

SQL Server数

2010-06-12 10:10:55

2010-07-15 15:37:13

SQL Server数

2010-07-20 15:43:42

SQL Server

2010-07-06 15:22:00

SQL Server

2010-07-01 15:44:22

SQL Server数

2009-04-16 15:26:32

Sql Server记录总数聚簇索引

2010-06-28 10:06:09

SQL Server数

2011-03-28 09:40:41

2010-08-11 14:10:40

DB2连接服务器

2011-04-06 16:25:47

SQL Server

2010-08-05 08:54:03

DB2连接服务器

2010-07-22 16:02:29

2010-09-02 11:14:39

SQL删除日志
点赞
收藏

51CTO技术栈公众号