sql >> Databasteknik >  >> RDS >> Sqlserver

SQL Server Databas Size Growth med hjälp av Backup-historik

Hej,

Chefer och kunder frågar ofta vad databasens storlek ökar.

Tillväxtgrafik för databasstorlek är mycket viktig för den nya lagringsordern. Eftersom Enterprise-företag vill köpa ny lagring inom ett eller två år, inte varannan till var tredje månad.

Du kan analysera databasstorleksökningen med hjälp av säkerhetskopieringshistorik med följande skript.

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 NOT BS.database_name IN
('master', 'msdb', 'model', 'tempdb')
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;


  1. Duplicera rader baserat på ett kolumnvärde i varje rad

  2. 7 strategier för att få ut det mesta av dina möten

  3. Hur man använder Coalesce Function i Oracle

  4. MySQL – MINSTA och STÖRSTA jämförelseoperatörer