zoukankan      html  css  js  c++  java
  • 查看MS SQL Server数据库每个表占用的空间大小

    参数说明见:http://msdn.microsoft.com/zh-cn/library/ms188776.aspx

    create table #t(name varchar(255), rows bigint, reserved varchar(20)
    , data varchar(20), index_size varchar(20), unused varchar(20))
    exec sp_MSforeachtable "insert into #t exec sp_spaceused '?'"
    --select * from #t
    select [name] '表名',[rows]'行数',reserved '为 objname 保留的空间总量',data 'objname 中的数据所使用的空间总量'
    ,index_size 'objname 中的索引所使用的空间总量' ,unused '为 objname 保留但尚未使用的空间总量' from #t
    order by cast(left(ltrim(rtrim(reserved)) , len(ltrim(rtrim(reserved)))-2) as int) desc
    drop table #t

    我一般上面的或下面第二种

    来源:IT学习者 网址:http://www.itlearner.com/

    [导读]我在工作中碰到了一些问题,需要查看数据库表的大小,查询SQL Server联机从书得到如下语句: sp_spaceused 显示行数、保留的磁盘空间以及当前数据库中的表所使用的磁盘空间,或显示由整个数据库保留和使用的磁盘空间...

    我在工作中碰到了一些问题,需要查看数据库表的大小,查询SQL Server联机从书得到如下语句:

    sp_spaceused

    显示行数、保留的磁盘空间以及当前数据库中的表所使用的磁盘空间,或显示由整个数据库保留和使用的磁盘空间。

    语法

    sp_spaceused [[@objname ='objname']
        [,[@updateusage =] 'updateusage']

    参数

    [@objname ='objname'

    是为其请求空间使用信息(保留和已分配的空间)的表名。objname 的数据类型是 nvarchar(776),默认设置为 NULL。

    [@updateusage =] 'updateusage'

    表示应在数据库内(未指定 objname 时)还是在特定的对象上(指定 objname 时)运行 DBCC UPDATEUSAGE。值可以是 true 或 falseupdateusage 的数据类型是 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

  • 相关阅读:
    手机的基本功能测试情景模式
    C#.net技术内幕04集合
    .net 发送电子邮件
    SQL:select case when(转)
    《 C#技术内幕》学习01IDisposable
    C#.net技术内幕03字符串
    点击确定后页面跳转
    SQL注入式攻击
    C#.NET技术内幕 02表达式
    window xp自带的功能之繁体字
  • 原文地址:https://www.cnblogs.com/ylemzhang/p/2973788.html
Copyright © 2011-2022 走看看