【转载】查看MSSQL数据库每个表占用的空间大小的方法

摘要:
sp_Spaceused显示当前数据库中的表所使用的行数、保留的磁盘空间和磁盘空间,或整个数据库所保留和使用的磁盘空间。USEpubsXECsp_空格使用的“标题”B。以下示例总结了当前数据库使用的空间,并使用了可选参数@updateusage。USEpubssp_spaceused@updateusage='TRUE'但是,此方法只能查看一个表的大小。通常,数据库中有多个表。如何一次查看数据库的所有表大小?

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

免责声明:文章转载自《【转载】查看MSSQL数据库每个表占用的空间大小的方法》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Python之os库的使用xpath获取下一页,兄弟节点的妙用下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

利用mybatis连接mysql数据库进行数据的操作

整体结构如下: 首先写大配置,该配置的作用是连接数据库。    可以将连接数据库的方法单独提出来,写在jdbc.propterties中,代码如下: jdbc.driver=com.mysql.jdbc.Driver //加载驱动jdbc.url=jdbc:mysql://localhost:3306/school //连接mysql数据库jdbc...

数据库测试数据自动生成工具

数据库测试数据自动生成工具——TestBytes 在数据库开发的过程中,为了测试应用程序对数据库的访问,应当在数据库中生成测试用例数据,我们可能会发现当数据库中只有少量数据时,程序可能没有问题,但是当真正投入到运用中产生了大量数据时就出现问题了,这往往是因为程序的编写没有达到,所以一定及早地通过在数据库中生成大量数据来帮助开发人员完善这部分功能和性能。...

MongoDB学习笔记(一) MongoDB介绍及安装

MongoDB简介 MongoDB是一个高性能,开源,无模式的文档型数据库,是当前NoSql 数据库中比较热门的一种。它在许多场景下可用于替代传统的关系型数据库或键/值存储方式。Mongo使用C++开发。Mongo的官方网站地址是:http://www.mongodb.org/,读者可以在此获得更详细的信息。 特点 高性能、易部署、易使用,存储数据非常方便...

[转]DbHelper通用数据库访问帮助类

之前我一直都是在博客园中查看各位高手的博文,确实学到了不少知识,不过比较少写博客,现在就把我自己在项目实施过程中使用到比较好的技术框架写出来,希望能让更多的人了解和学习。      通常我们在开发使用数据库访问帮助类时,都单独的针对某一种数据进行编写相应的数据访问帮助类,如SQLHelper,OracleHelper,OleDbHelper等,其实这些都帮...

微服务架构 SpringBoot(二)

第二天内容:想来想去玩个ssm小demo吧1.创建表 2..引入相关mybatis 数据库jar: <!--mybatis --> <dependency>   <groupId>org.mybatis.spring.boot</groupId>   <artifactId>mybatis-s...

C# ManagedDataAccess 操作oracle数据库

C# ManagedDataAccess 操作oracle数据库 甲骨文官方制作的oracle类库优点是无需安装oracle客户端 环境准备 Nuget安装 Oracle.ManagedDataAccess 引用 using Oracle.ManagedDataAccess.Client; 连接oracle数据库 连接字符串 connStr = @"Da...