zoukankan      html  css  js  c++  java
  • 数据库表空间大小统计

    <?php
    define
    ("CFG_OSTYPE", "linux");          // 操作系统类型,linux | windows
    define("CFG_DBTYPE","oracle");          // 数据库类型,mysql | mssql | oracle
    define("CFG_SQLSERVER","localhost");    // 数据库服务器名
    define("CFG_SQLUSER","root");           // 数据库用户名
    define("CFG_SQLPASSWORD","root@sql");   // 数据库用户密码
    define("CFG_DATABASE","testdb");        // 数据库名

    require_once('./DB.php');

    //数据库占用空间
    $DbSize = 0;
    switch(
    CFG_DBTYPE)
    {
        case
    "mysql":
            {
                
    $sql = "SHOW TABLE STATUS FROM ".CFG_DATABASE;
                
    $res = $DB->sql_query($sql);
                while(
    $row = $DB->sql_fetchrow($res))
                {
                    
    $DbSize += $row['Data_length'];
                }
                
    $DB->sql_freeresult();
                
    $DbSize = intval($DbSize/1024);
            }
            break;
        case
    "mssql":
            {
                
    $sql = "SELECT SUM(CONVERT(float,size)) * (8192.0/1024.0) AS spaceused FROM [dbo].[sysfiles]";
                
    $res = $DB->sql_query($sql);
                
    $row = $DB->sql_fetchrow($res);
                
    $DbSize = intval($row['spaceused']);
                
    $DB->sql_freeresult();
            }
            break;
        case
    "oracle":
            {
                
    $sql = "SELECT DISTINCT ((c.BYTES-b.BYTES)/1024) as spaceused FROM dba_tables a,dba_free_space b,dba_data_files c WHERE a.OWNER='".strtoupper(CFG_DATABASE)."' and a.TABLESPACE_NAME=b.TABLESPACE_NAME and a.TABLESPACE_NAME=c.TABLESPACE_NAME";
                
    $res = $DB->sql_query($sql);
                
    $row = $DB->sql_fetchrow($res);
                
    $DbSize = intval($row['spaceused']);
                
    $DB->sql_freeresult();
            }
            break;
    }

    echo
    "数据库占用空间:".$DbSize." K";
    ?>
  • 相关阅读:
    设计模式(三)原型模式
    PageHelper在Mybatis中的使用
    设计模式(二) 单例模式
    设计模式(一)简单工厂、工厂方法和抽象工厂
    Java网络编程
    循环控制语句if 、for、case、while
    处理海量数据的grep、cut、awk、sed 命令
    shell脚本的输入以及脚本拥有特效地输出
    shell的变量以及常见符号
    shell的使用技巧
  • 原文地址:https://www.cnblogs.com/longware/p/13382432.html
Copyright © 2011-2022 走看看