zoukankan      html  css  js  c++  java
  • 计算数据库中各个表的数据量和每行记录所占用空间

    -- =============================================
    -- Author:      <奔跑的金鱼>
    -- Blog:        <http://www.cnblogs.com/OliverQin/>
    -- Create date: <2015/01/05>
    -- Description: <>
    -- =============================================
    select * from #tablespaceinfo
    --------------------------------创建临时表
    CREATE TABLE #tablespaceinfo
        (
          nameinfo     VARCHAR(500) ,    
          rowsinfo     BIGINT ,         
          reserved     VARCHAR(20) ,    
          datainfo     VARCHAR(20) ,
          index_size   VARCHAR(20) ,
          unused       VARCHAR(20)
        )  
    -------------------------------声明变量
    DECLARE @tablename VARCHAR(255);  
    
    --------------------------------使用游标存储从数据库中获取的实体表名
    DECLARE Info_cursor CURSOR
    FOR
        SELECT  '[' + [name] + ']'
        FROM    sys.tables
        WHERE   type = 'U';  
     
    OPEN Info_cursor  
    FETCH NEXT FROM Info_cursor INTO @tablename  
     
    WHILE @@FETCH_STATUS = 0
        BEGIN 
            INSERT  INTO #tablespaceinfo
                    EXEC sp_spaceused @tablename  
            FETCH NEXT FROM Info_cursor  
        INTO @tablename  
        END 
     
    CLOSE Info_cursor  
    DEALLOCATE Info_cursor  
     
    --创建临时表
    CREATE TABLE [#tmptb]
        (
          TableName VARCHAR(50) ,
          DataInfo BIGINT ,
          RowsInfo BIGINT ,
          Spaceperrow  AS ( CASE RowsInfo
                             WHEN 0 THEN 0
                             ELSE CAST(DataInfo AS decimal(18,2))/CAST(RowsInfo AS decimal(18,2))
                           END ) PERSISTED
        )
    
    --插入数据到临时表
    INSERT  INTO [#tmptb]
            ( [TableName] ,
              [DataInfo] ,
              [RowsInfo]
            )
            SELECT  [nameinfo] ,
                    CAST(REPLACE([datainfo], 'KB', '') AS BIGINT) AS 'datainfo' ,
                    [rowsinfo]
            FROM    #tablespaceinfo
            ORDER BY CAST(REPLACE(reserved, 'KB', '') AS INT) DESC  
    
    
    --汇总记录
    SELECT  [tbspinfo].* ,
            [tmptb].[Spaceperrow] AS '每行记录大概占用空间(KB)'
    FROM    [#tablespaceinfo] AS tbspinfo ,
            [#tmptb] AS tmptb
    WHERE   [tbspinfo].[nameinfo] = [tmptb].[TableName]
    ORDER BY CAST(REPLACE([tbspinfo].[reserved], 'KB', '') AS INT) DESC  
    
    DROP TABLE [#tablespaceinfo]
    DROP TABLE [#tmptb]
  • 相关阅读:
    SqlBulkCopy类进行大数据(10000万条以上)插入测试
    win7 64位下android开发环境的搭建
    Linq语法详细
    理解ASP.NET MVC中的ActionResult
    webBrowser 模拟登录
    C#中的WebBrowser控件的使用
    httpwebrequest详解【转】
    Post方式调用wcf服务
    EXTJS4.2 控件之Grid getRowClass 添加行背景色
    SQL 跨服务器数据库增、删、改、查(二)
  • 原文地址:https://www.cnblogs.com/OliverQin/p/5105432.html
Copyright © 2011-2022 走看看