• SQLSERVER 和 ORACLE 查询数据库文件大小


    SQLSERVER:

    SQLSERVER一个库的文件分为数据文件(行数据)和日志文件两个文件,详情可以在数据库的属性->文件中查看。

    在资源管理器中打开文件所在路径可以直接看到这两个文件

    但是,大多数时候我们的数据库安装在远程服务器上,在不远程的情况下,可以使用如下SQL语句:

    1、查询各个磁盘分区的剩余空间(就是C盘还有多少空间,D盘还有多少...):

    Exec master.dbo.xp_fixeddrives

    2、查询数据库的数据文件及日志文件的相关信息(包括文件组、当前文件大小、文件最大值、文件增长设置、文件逻辑名、文件路径等):

    select * from [数据库名].[dbo].[sysfiles]
    --转换文件大小单位为MB:
    select name, convert(float,size) * (8192.0/1024.0)/1024. from [数据库名].dbo.sysfiles

    3、查询当前数据库的磁盘使用情况:

    Exec sp_spaceused

    database_size:数据库大小(就是数据文件和日志的大小),也就是上面size相加的值(字节换算成兆)

    unallocated space:未分配空间。

    4、查询数据库服务器各数据库日志文件的大小及利用率:

    DBCC SQLPERF(LOGSPACE)

    5、查看数据文件占用(所需权限较大):

    DBCC showfilestats  

    6、一个全面的SQL:

    SELECT a.name [文件名称]  
        ,cast(a.[size]*1.0/128 as decimal(12,1)) AS [文件设置大小(MB)]  
        ,CAST( fileproperty(s.name,'SpaceUsed')/(8*16.0) AS DECIMAL(12,1)) AS [文件所占空间(MB)]  
        ,CAST( (fileproperty(s.name,'SpaceUsed')/(8*16.0))/(s.size/(8*16.0))*100.0  AS DECIMAL(12,1)) AS [所占空间率%]  
        ,CASE WHEN A.growth =0 THEN '文件大小固定,不会增长' ELSE '文件将自动增长' end [增长模式]  
        ,CASE WHEN A.growth > 0 AND is_percent_growth = 0 THEN '增量为固定大小'  
            WHEN A.growth > 0 AND is_percent_growth = 1 THEN '增量将用整数百分比表示'  
            ELSE '文件大小固定,不会增长' END AS [增量模式]  
        ,CASE WHEN A.growth > 0 AND is_percent_growth = 0 THEN cast(cast(a.growth*1.0/128as decimal(12,0)) AS VARCHAR)+'MB'  
            WHEN A.growth > 0 AND is_percent_growth = 1 THEN cast(cast(a.growth AS decimal(12,0)) AS VARCHAR)+'%'  
            ELSE '文件大小固定,不会增长' end AS [增长值(%或MB)]  
        ,a.physical_name AS [文件所在目录]  
        ,a.type_desc AS [文件类型]  
    FROM sys.database_files  a  
    INNER JOIN sys.sysfiles AS s ON a.[file_id]=s.fileid  
    LEFT JOIN sys.dm_db_file_space_usage b ON a.[file_id]=b.[file_id]  

    其中的文件设置大小就是该数据库的文件大小

    ORACLE:

    在PL/SQL中我没有找到有关于数据库文件的信息,有可能还没找到吧。所以直接采用查询的方式

    1、SYS.DBA_DATA_FILES:

    select * from dba_data_files;

    这边的FILE_NAME就是文件路径,BYTES就是所占空间了。

    根据这个路径找到数据文件:

    2、一个全面的SQL:

    SELECT UPPER(F.TABLESPACE_NAME) "表空间名",
    
    D.TOT_GROOTTE_MB "表空间大小(M)",
    
    D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空间(M)",
    
    TO_CHAR(ROUND((D.TOT_GROOTTE_MB - F.TOTAL_BYTES) / D.TOT_GROOTTE_MB * 100,2),'990.99') || '%' "使用比",
    
    F.TOTAL_BYTES "空闲空间(M)",
    
    F.MAX_BYTES "最大块(M)"
    
    FROM (SELECT TABLESPACE_NAME,
    
    ROUND(SUM(BYTES) / (1024 * 1024), 2) TOTAL_BYTES,
    
    ROUND(MAX(BYTES) / (1024 * 1024), 2) MAX_BYTES
    
    FROM SYS.DBA_FREE_SPACE
    
    GROUP BY TABLESPACE_NAME) F,
    
    (SELECT DD.TABLESPACE_NAME,
    
    ROUND(SUM(DD.BYTES) / (1024 * 1024), 2) TOT_GROOTTE_MB
    
    FROM SYS.DBA_DATA_FILES DD
    
    GROUP BY DD.TABLESPACE_NAME) D
    
    WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME
    
    ORDER BY 1;

    MrNou
  • 相关阅读:
    git基础使用小记
    MYSQL 安装&配置
    NGINX 安装&配置
    PHP编译安装
    linux基本命令操作
    css清除浮动的8种方法以及优缺点
    简单概括下浏览器事件模型,如何获得资源dom节点
    HTML5新增的表单元素有哪些?
    css 引入的方式有哪些, link和@import的区别是什么
    git与svn的区别
  • 原文地址:https://www.cnblogs.com/yangsirc/p/10026914.html
Copyright © 2020-2023  润新知