程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> SQL Server自動增長過大的問題

SQL Server自動增長過大的問題

編輯:關於SqlServer

一、背景

我們遇到的問題如下圖所示:自動增長無端端就按照這樣的比例進行增長;

(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

查看本欄目

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved