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";
    ?>
  • 相关阅读:
    跨域现象及原理分析
    git的commit撤销
    什么是幂等,什么情况下需要幂等,如何实现幂等
    flowable表简要说明
    关于SpringCloud、SpringBoot简单讲解
    常用的maven仓库地址
    Python安装第三方库常用方法
    反编译pyinstaller打包的exe安装包
    测试用例-需要添加@Transactional 这样 就不会再数据库里面留下痕迹了
    断点 太多了 调试运行特别慢-把所有的历史断点都去掉就快了
  • 原文地址:https://www.cnblogs.com/longware/p/13382432.html
Copyright © 2011-2022 走看看