zoukankan      html  css  js  c++  java
  • 【转载】查看MSSQL数据库每个表占用的空间大小的方法

    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

  • 相关阅读:
    HTML学习笔记4----更多元素
    USB协议分析
    USB总线介绍
    SPI驱动程序设计
    SPI子系统
    SPI总线介绍和裸机编程分析
    I2C自编设备驱动设计
    I2C用户态驱动设计
    I2C学习
    MTD系统架构和yaffs2使用、Nandflash驱动设计
  • 原文地址:https://www.cnblogs.com/wonder315/p/2173938.html
Copyright © 2011-2022 走看看