如何通過SQL命令查看數據庫的文件大小[轉]


1. 查看數據文件占用(權限要求較大)

DBCC showfilestats  

2. 查看日志文件占用

dbcc sqlperf(logspace)   

會列出所有能夠查看的數據庫的日志情況.. 需要挑選出當前數據庫..

 

3.全面查看

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]  

 

親測可用..

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM