Es gibt viele Möglichkeiten, wie Sie die Datenbankkapazität planen können.
Wenn der MSDB-Sicherungsverlauf regelmäßig gekürzt wird, bleiben nicht mehr viele Daten für die Analyse übrig
Wie Mark betonte, kann dies mit der von Erin beschriebenen Methode erfolgen - Trenddatenbankwachstum aus dem Backup.
Sie können sogar PIVOT verwenden, um das Datenbankwachstum über einen Zeitraum von 12 Monaten aus dem Sicherungsverlauf wie folgt zu ermitteln:
DECLARE @startDate DATETIME;
SET @startDate = GetDate();
SELECT PVT.DatabaseName
,PVT.[0]
,PVT.[-1]
,PVT.[-2]
,PVT.[-3]
,PVT.[-4]
,PVT.[-5]
,PVT.[-6]
,PVT.[-7]
,PVT.[-8]
,PVT.[-9]
,PVT.[-10]
,PVT.[-11]
,PVT.[-12]
FROM (
SELECT BS.database_name AS DatabaseName
,DATEDIFF(mm, @startDate, BS.backup_start_date) AS MonthsAgo
,CONVERT(NUMERIC(10, 1), AVG(BF.file_size / 1048576.0)) AS AvgSizeMB
FROM msdb.dbo.backupset AS BS
INNER JOIN msdb.dbo.backupfile AS BF ON BS.backup_set_id = BF.backup_set_id
WHERE BS.database_name NOT IN (
'master'
,'msdb'
,'model'
,'tempdb'
)
AND BS.database_name IN (
SELECT db_name(database_id)
FROM master.SYS.DATABASES
WHERE state_desc = 'ONLINE'
)
AND BF.[file_type] = 'D'
AND BS.backup_start_date BETWEEN DATEADD(yy, - 1, @startDate)
AND @startDate
GROUP BY BS.database_name
,DATEDIFF(mm, @startDate, BS.backup_start_date)
) AS BCKSTAT
PIVOT(SUM(BCKSTAT.AvgSizeMB) FOR BCKSTAT.MonthsAgo IN (
[0]
,[-1]
,[-2]
,[-3]
,[-4]
,[-5]
,[-6]
,[-7]
,[-8]
,[-9]
,[-10]
,[-11]
,[-12]
)) AS PVT
ORDER BY PVT.DatabaseName;
Es gibt noch einen anderen Weg, den Sie wirklich nützlich finden werden, wie er von Chad Miller in SSC - Database Space Capacity Planning hervorragend beschrieben wurde . Er konzentriert sich auch darauf, days remaining
was sehr nützlich ist.