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

SQLSERVER查询数据库文件大小_日志文件

 

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

SQLSERVER查询数据库文件大小_文件大小_02

 

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

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



Exec master.dbo.xp_fixeddrives


SQLSERVER查询数据库文件大小_sqlserver_03

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



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


SQLSERVER查询数据库文件大小_数据库_04

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



Exec sp_spaceused


SQLSERVER查询数据库文件大小_sqlserver_05

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

unallocated space:未分配空间。

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



DBCC SQLPERF(LOGSPACE)


SQLSERVER查询数据库文件大小_日志文件_06

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



DBCC showfilestats


SQLSERVER查询数据库文件大小_文件大小_07

6、一个全面的SQL:



SQLSERVER查询数据库文件大小_数据文件_08

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]


SQLSERVER查询数据库文件大小_数据文件_08


SQLSERVER查询数据库文件大小_数据文件_10

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