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

    CREATE TABLE #tablespaceinfo
        (
          nameinfo VARCHAR(50) ,
          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]

  • 相关阅读:
    绘制SVG内容到Canvas的HTML5应用
    HT for Web 3D游戏设计设计--汉诺塔(Towers of Hanoi)
    HT for Web自定义3D模型的WebGL应用
    纯Shading Language绘制飞机火焰效果
    纯Shading Language绘制HTML5时钟
    HTML5版的String Avoider小游戏
    基于HT的CSG功能构建HTML5的3D书架
    HTML5 Web 客户端五种离线存储方式汇总
    基于HTML5的Drag and Drop生成图片Base64信息
    HT for Web可视化QuadTree四叉树碰撞检测
  • 原文地址:https://www.cnblogs.com/nickkuang/p/3829335.html
Copyright © 2011-2022 走看看