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";
    ?>
  • 相关阅读:
    python jinja2模板分页效果
    vscode配置svn
    解决VSCODE打开新文件覆盖上一个窗口的问题
    vue所用插件整理
    vue bus总线
    create-react-app使用less
    react入门
    ES6|Object
    vue轮播插件--vue-awesome-swiper
    js/jq中遍历对象或者数组的函数(foreach,map,each)
  • 原文地址:https://www.cnblogs.com/longware/p/13382432.html
Copyright © 2011-2022 走看看