确定SQL Server数据库大小


77

SQL Server 2005/2008 Express版每个数据库的限制为4 GB。据我所知,数据库引擎仅考虑数据,因此不包括日志文件,未使用的空间和索引大小。

就SQL Server限制而言,获取MDF文件的长度不应提供正确的数据库大小。我的问题是如何获取数据库大小?

Answers:


102

sp_spaceused


7
sp_spaceused考虑了日志文件的大小,因此,如果您有一个很小的数据库和一个很大的日志文件,则在尝试确定您与4GB限制的距离时,sp_spaceused的结果将产生误导。
拉马尔

77

sp_helpdb

与sp_spaceused不同,不需要循环。


5
给出分配的数据库大小(mdf文件的大小),而不是实际使用的大小。
Mrchief

16

根据SQL2000帮助,sp_spaceused包含数据和索引。

该脚本应执行以下操作:

CREATE TABLE #t (name SYSNAME, rows CHAR(11), reserved VARCHAR(18), 
data VARCHAR(18), index_size VARCHAR(18), unused VARCHAR(18))

EXEC sp_msforeachtable 'INSERT INTO #t EXEC sp_spaceused ''?'''
-- SELECT * FROM #t ORDER BY name
-- SELECT name, CONVERT(INT, SUBSTRING(data, 1, LEN(data)-3)) FROM #t ORDER BY name
SELECT SUM(CONVERT(INT, SUBSTRING(data, 1, LEN(data)-3))) FROM #t
DROP TABLE #t

这是一个很好的答案。感谢您的脚本-非常有帮助!
凯文·巴布科克


8

最好的解决方案可能是使用sys.sysfiles视图计算每个数据库文件的大小,并考虑每个页面8 KB的大小,如下所示:

USE [myDatabase]
GO

SELECT
    [size] * 8
    , [filename]
FROM sysfiles

[field]列以页为单位表示文件的大小(MSDN参考sysfiles)。

您将看到至少有两个文件(MDF和LDF):这些文件的总和将为您提供整个数据库的正确大小...


6
+1SELECT SUM(size)/128.0 AS size FROM sysfiles返回与相同的值sp_spaceused,但可能更易于自动分析。
Eugene Ryabtsev

5

我一直喜欢直接遵循它:

SELECT 
    DB_NAME( dbid ) AS DatabaseName, 
    CAST( ( SUM( size ) * 8 ) / ( 1024.0 * 1024.0 ) AS decimal( 10, 2 ) ) AS DbSizeGb 
FROM 
    sys.sysaltfiles 
GROUP BY 
    DB_NAME( dbid )

2
请注意,在SQL 2005 +中,基本用户帐户(即没有特殊权限的用户帐户)无法读取sysaltfiles。即使将登录名添加到master数据库并在master..sysaltfiles或sys.sysaltfiles上添加了GRANT SELECT,此表上的select语句也将返回空记录集。使用系统管理员帐户没有问题。
迈克

2

您也可以使用这种老式的...

set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
go

DECLARE @iCount int, @iMax int, @DatabaseName varchar(200), @SQL varchar (8000)

Select NAME, DBID, crdate, filename, version 
INTO #TEMP
from MAster..SYSDatabASES 

SELECT @iCount = Count(DBID) FROM #TEMP

Select @SQL='Create Table ##iFile1 ( DBName varchar( 200) NULL, Fileid INT, FileGroup int, TotalExtents INT , USedExtents INT , 
Name varchar(100), vFile varchar (300), AllocatedSpace int NUll, UsedSpace int Null, PercentageFree int Null ) '+ char(10)
exec (@SQL)


Create Table ##iTotals ( ServerName varchar(100), DBName varchar( 200) NULL, FileType varchar(10),Fileid INT, FileGroup int, TotalExtents INT , USedExtents INT , 
Name varchar(100), vFile varchar (300), AllocatedSpace int NUll, UsedSpace int Null, PercentageFree int Null ) 


WHILE @iCount>0
BEGIN    
    SELECT @iMax =Max(dbid) FROM #TEMP
    Select @DatabaseName = Name FROM #TEMP where dbid =@iMax

    SELECT @SQL = 'INSERT INTO ##iFile1(Fileid , FileGroup , TotalExtents  , USedExtents  , Name , vFile)
     EXEC (''USE [' + @DatabaseName +  '] DBCC showfilestats'')    ' + char(10)

    Print  (@SQL)
    EXEC (@SQL)


    SELECT @SQL = 'UPDATE ##iFile1 SET DBName ='''+ @DatabaseName +''' WHERE DBName IS NULL'
    EXEC  (@SQL)


    DELETE FROM #TEMP WHERE dbid =@iMax
    Select @iCount =@iCount -1
END
UPDATE ##iFile1
SET AllocatedSpace = (TotalExtents * 64.0 / 1024.0 ), UsedSpace =(USedExtents * 64.0 / 1024.0 )

UPDATE ##iFile1
SET PercentageFree = 100-Convert(float,UsedSpace)/Convert(float,AllocatedSpace   )* 100
WHERE USEDSPACE>0

CREATE TABLE #logspace (
   DBName varchar( 100),
   LogSize float,
   PrcntUsed float,
   status int
   )
INSERT INTO #logspace
EXEC ('DBCC sqlperf( logspace)')



INSERT INTO ##iTotals(ServerName, DBName, FileType,Name, vFile,PercentageFree,AllocatedSpace)
select @@ServerName ,DBNAME,  'Data' as FileType,Name, vFile, PercentageFree  , AllocatedSpace
from ##iFile1
UNION
select @@ServerName ,DBNAME, 'Log' as FileType ,DBName,'' as vFile ,PrcntUsed  , LogSize
from #logspace

Select * from ##iTotals

select ServerName ,DBNAME,  FileType, Sum( AllocatedSpace) as AllocatedSpaceMB
from ##iTotals
Group By  ServerName ,DBNAME, FileType
Order By  ServerName ,DBNAME, FileType


select ServerName ,DBNAME,  Sum( AllocatedSpace) as AllocatedSpaceMB
from ##iTotals
Group By  ServerName ,DBNAME
Order By  ServerName ,DBNAME



drop table ##iFile1
drop table #logspace
drop table #TEMP
drop table ##iTotals

0

在SQL Server中同时支持Azure和本地-的通用查询来检查数据库大小-

方法1 –使用“ sys.database_files”系统视图

SELECT
    DB_NAME() AS [database_name],
    CONCAT(CAST(SUM(
        CAST( (size * 8.0/1024) AS DECIMAL(15,2) )
    ) AS VARCHAR(20)),' MB') AS [database_size]
FROM sys.database_files;

方法2 –使用“ sp_spaceused”系统存储过程

EXEC sp_spaceused ;
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.