SQLSERVER 和 ORACLE 查询数据库文件大小
SQLSERVER:
SQLSERVER一個庫的文件分為數(shù)據(jù)文件(行數(shù)據(jù))和日志文件兩個文件,詳情可以在數(shù)據(jù)庫的屬性->文件中查看。
?
在資源管理器中打開文件所在路徑可以直接看到這兩個文件
?
但是,大多數(shù)時候我們的數(shù)據(jù)庫安裝在遠(yuǎn)程服務(wù)器上,在不遠(yuǎn)程的情況下,可以使用如下SQL語句:
1、查詢各個磁盤分區(qū)的剩余空間(就是C盤還有多少空間,D盤還有多少...):
Exec master.dbo.xp_fixeddrives2、查詢數(shù)據(jù)庫的數(shù)據(jù)文件及日志文件的相關(guān)信息(包括文件組、當(dāng)前文件大小、文件最大值、文件增長設(shè)置、文件邏輯名、文件路徑等):
select * from [數(shù)據(jù)庫名].[dbo].[sysfiles] --轉(zhuǎn)換文件大小單位為MB: select name, convert(float,size) * (8192.0/1024.0)/1024. from [數(shù)據(jù)庫名].dbo.sysfiles3、查詢當(dāng)前數(shù)據(jù)庫的磁盤使用情況:
Exec sp_spaceuseddatabase_size:數(shù)據(jù)庫大小(就是數(shù)據(jù)文件和日志的大小),也就是上面size相加的值(字節(jié)換算成兆)
unallocated space:未分配空間。
4、查詢數(shù)據(jù)庫服務(wù)器各數(shù)據(jù)庫日志文件的大小及利用率:
DBCC SQLPERF(LOGSPACE)5、查看數(shù)據(jù)文件占用(所需權(quán)限較大):
DBCC showfilestats6、一個全面的SQL:
SELECT a.name [文件名稱] ,cast(a.[size]*1.0/128 as decimal(12,1)) AS [文件設(shè)置大小(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 '增量將用整數(shù)百分比表示' 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]其中的文件設(shè)置大小就是該數(shù)據(jù)庫的文件大小
ORACLE:
在PL/SQL中我沒有找到有關(guān)于數(shù)據(jù)庫文件的信息,有可能還沒找到吧。所以直接采用查詢的方式
1、SYS.DBA_DATA_FILES:
select * from dba_data_files;這邊的FILE_NAME就是文件路徑,BYTES就是所占空間了。
根據(jù)這個路徑找到數(shù)據(jù)文件:
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_BYTESFROM SYS.DBA_FREE_SPACEGROUP BY TABLESPACE_NAME) F,(SELECT DD.TABLESPACE_NAME,ROUND(SUM(DD.BYTES) / (1024 * 1024), 2) TOT_GROOTTE_MBFROM SYS.DBA_DATA_FILES DDGROUP BY DD.TABLESPACE_NAME) DWHERE D.TABLESPACE_NAME = F.TABLESPACE_NAMEORDER BY 1;轉(zhuǎn)載于:https://www.cnblogs.com/yangsirc/p/10026914.html
總結(jié)
以上是生活随笔為你收集整理的SQLSERVER 和 ORACLE 查询数据库文件大小的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。