获取SQL Server数据库里表占用容量大小

数据库 SQL Server
SQL Server数据库中表是数据库中最为重要的对象,没有了表的存在,其他的对象就无从说起,可见表在SQL Server数据库中的地位,SQL Server数据库就好比是一个大仓库,那么如何来获取SQL Server数据库里表占用容量的大小呢?

SQL Server数据库中可以储存很多的数据,但是SQL Server数据库的内存是有一定的限制,而且达到一定的量就会对SQL Server数据库的操作产生影响,SQL Server数据库中也是占据一定的容量的,下面就教给大家获取SQL Server数据库里表占用容量大小的方法。

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

如:sp_spaceused 'tablename' 

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

 以下为引用的内容:
  CREATE PROCEDURE get_tableinfo AS
  
  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
  执行存储过程

  exec get_tableinfo
  查询运行该存储过程后得到的结果
  select *
  from tablespaceinfo
  order by cast(left(ltrim(rtrim(reserved)) , len(ltrim(rtrim(reserved)))-2) as int) desc

 

 这就是我要为大家介绍的关于获取SQL Server数据库里表占用容量大小方法的全部内容,更多的方法技巧还需要大家自己去发现总结,希望上文中介绍的内容对大家能够有所帮助。

【编辑推荐】

  1. SQL Server数据库对上亿表的操作
  2. MySQL数据库单一表突破4G限制的实现方法
  3. SQL Server数据库对上亿表的操作
  4. SQL Server中如何快速获取表的记录总数
责任编辑:迎迎 来源: 中国IT实验室
相关推荐

2019-09-17 07:31:53

MySQL表容量数据库

2019-09-17 08:23:35

MySQL数据库容量

2010-07-13 15:56:16

SQL Server获

2011-08-15 15:53:51

SQL Server数批量操作

2011-03-22 13:49:20

SQL Server数维度表事实表

2010-06-18 11:04:39

SQL Server

2010-07-15 17:28:50

SQL Server

2022-06-14 09:52:39

ArrayList初始化容量

2010-10-13 09:30:45

SQL Server

2010-09-25 15:37:38

SQL语句

2010-07-09 11:28:12

SQL Server数

2010-06-28 09:43:05

SQL Server数

2011-03-30 16:10:08

SQL Server数内存

2010-07-15 09:47:09

SQL Server数

2009-04-16 15:26:32

Sql Server记录总数聚簇索引

2009-03-30 15:52:24

数据导入导出SQL Server

2011-04-07 13:53:04

SQL Server数

2010-09-10 13:37:30

表分区SQL Server

2011-07-20 16:03:06

SQL Server数分区表

2011-04-13 09:31:50

Oracle
点赞
收藏

51CTO技术栈公众号