一、背景
我們遇到的問題如下圖所示:自動增長無端端就按照這樣的比例進行增長;
(Figure1:問題所在)
嘗試使用SSMS修改自動增長值,就會出現下面的錯誤:
(Figure2:錯誤信息)
遇到上面的問題,我們需要解決兩個問題:
1. 把數據文件收縮到一定范圍內的值,騰出磁盤空間;
2. 重新設置自動增長的值,可以按照百分比,也可以使用指定的空間大小,我個人傾向使用n*1024M這樣的值,僅供參考;
3. 如果有需要你也可以進行日志文件的收縮;
二、解決過程
1. 使用下面的腳本修改自動增長的值:
--1024 ALTER DATABASE [DataBaseName] MODIFY FILE ( NAME = N'FileName', FILEGROWTH = 1024MB ) GO
(圖3:效果)
上面是執行了按照1024MB的空間執行的效果,如果你想用百分比的可以使用下面的SQL:
--10% ALTER DATABASE [DataBaseName] MODIFY FILE ( NAME = N'FileName', FILEGROWTH = 10%) GO
2. 使用下面的腳本收縮數據:(默認是是以MB作為單位的)
--12000MB USE [DataBaseName] GO DBCC SHRINKFILE (N'FileName' , 12000) GO
(Figure4:效果)
(Figure5:效果)
3. 如果有需要你也可以進行日志文件的收縮:(需要簡單模式,如果在完整模式下,你需要進行的是日志文件的備份)
--sql server 2005 BACKUP LOG [DataBaseName] WITH NO_LOG DBCC SHRINKDATABASE ([DataBaseName],TRUNCATEONLY) --sql server 2008 ALTER DATABASE [DataBaseName] SET RECOVERY SIMPLE GO -- 收縮 DBCC SHRINKFILE (2,30) --30單位為M,日志文件的大小 GO -- 更改模式為FULL ,再改回來,如果本身就已是simple,那就不必要了 ALTER DATABASE [DataBaseName] SET RECOVERY FULL GO
查看本欄目