一、背景
我们遇到的问题如下图所示:自动增长无端端就按照这样的比例进行增长;
(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
查看本栏目更多精彩内容:http://www.bianceng.cnhttp://www.bianceng.cn/database/SQLServer/
以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索问题
, 文件
, database
, 自动
, 自动增长
, databasename
, 收缩
, 日志文件过大
, 文件增长
自动增长值
sql server 自动增长、sqlserver 自动增长、sql server自动增长列、sqlserver 自动增长列、sqlserver id自动增长,以便于您获取更多的相关知识。