SQLSERVER查询数据库文件大小
SQLSERVER一個庫的文件分為數據文件(行數據)和日志文件兩個文件,詳情可以在數據庫的屬性->文件中查看。
在資源管理器中打開文件所在路徑可以直接看到這兩個文件
但是,大多數時候我們的數據庫安裝在遠程服務器上,在不遠程的情況下,可以使用如下SQL語句:
1、查詢各個磁盤分區(qū)的剩余空間(就是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相加的值(字節(jié)換算成兆)
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]
其中的文件設置大小就是該數據庫的文件大小
.zstitle { 280px; text-align: center; font-size: 26px }
.zsimgweixin { 280px }
.zsimgali { 280px; padding: 0px 0px 50px 0px }
.zsleft { float: left }
.zsdiv { display: flex }
.zs { font-size: 30px }
.zspaddingright { padding: 0px 100px 0px 0px }
喜歡請贊賞一下啦^_^
微信贊賞
支付寶贊賞
總結
以上是生活随笔為你收集整理的SQLSERVER查询数据库文件大小的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: stdio
- 下一篇: 怎样正确设置路由器家用路由器如何设置