我有個數據庫statmemberdata現在的日志文件都達到40G了,我要用DBCC SHRINKDATABASE來收縮這個日志,過程如下:
1、重新啟動數據服務器(通過遠程控制軟件進行的)
2、在遠程通過SQL SERVER的查詢分析器中連接到數據服務器
3、遠程控制數據服務器服務暫停
4、過十分鐘,在遠程查詢分析器中執行:
?? DBCC SHRINKDATABASE (statmemberdata)
?? 過了幾分鐘出現以下錯誤:
?? “無法收縮日志文件 2(statmemberdata_log),因為所有的邏輯日志文件都在使用。
(所影響的行數為 2 行)
DBCC 執行完畢。如果 DBCC 輸出了錯誤信息,請與系統管理員聯系。”
我不明白了,我都重新啟動了數據服務器,啟動完后馬上有暫停了sql server的服務,然后又過了一段時間才運行DBCC SHRINKDATABASE的,怎么老是說“所有的邏輯日志文件都在使用”呢,都試過好多次了,都是這樣。
----------------------------------------------------------------------------------------------------------------
1: 刪除LOG
1:分離數據庫?? 企業管理器->服務器->數據庫->右鍵->分離數據庫
2:刪除LOG文件
3:附加數據庫? 企業管理器->服務器->數據庫->右鍵->附加數據庫
此法生成新的LOG,大小只有500多K
?? 再將此數據庫設置自動收縮
或用代碼:
下面的示例分離 pubs,然后將 pubs 中的一個文件附加到當前服務器。
EXEC sp_detach_db @dbname = 'pubs'
EXEC sp_attach_single_file_db @dbname = 'pubs',
?? @physname = 'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs.mdf'
2:清空日志
DUMP? TRANSACTION? 庫名? WITH? NO_LOG???
再:
企業管理器--右鍵你要壓縮的數據庫--所有任務--收縮數據庫--收縮文件--選擇日志文件--在收縮方式里選擇收縮至XXM,這里會給出一個允許收縮到的最小M數,直接輸入這個數,確定就可以了
3: 如果想以后不讓它增長
企業管理器->服務器->數據庫->屬性->事務日志->將文件增長限制為2M
--壓縮日志
1:截斷事務日志:
BACKUP LOG 數據庫名 WITH NO_LOG
2:清空日志
DUMP TRANSACTION 庫名 WITH NO_LOG
再:
企業管理器--右鍵你要壓縮的數據庫--所有任務--收縮數據庫--收縮文件--選擇日志文件--在收縮方式里選擇收縮至XXM,這里會給出一個允許收縮到的最小M數,直接輸入這個數,確定就可以了
3: 刪除LOG
1:分離數據庫 企業管理器->服務器->數據庫->右鍵->分離數據庫
2:刪除LOG文件
3:附加數據庫 企業管理器->服務器->數據庫->右鍵->附加數據庫
此法生成新的LOG,大小只有500多K
再將此數據庫設置自動收縮
或用代碼:
下面的示例分離 pubs,然后將 pubs 中的一個文件附加到當前服務器。
EXEC sp_detach_db @dbname = 'pubs'
EXEC sp_attach_single_file_db @dbname = 'pubs',
@physname = 'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs.mdf'
對于有兩個庫文件的數據庫請用下面的語句:
exec sp_attach_db @dbname = 'pubs',
?@filename1 = 'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs.mdf',
?@filename2 = 'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs1_Data.NDF'
如果數據庫有兩個日志文件,則以上方法就不行了。
需要刪掉其中一個日志文件,方法如下:
截斷事務日志:
BACKUP LOG otsp WITH NO_LOG
清空日志
DUMP TRANSACTION otsp WITH NO_LOG
??
刪除LOG文件
企業管理器->服務器->數據庫->右鍵->屬性->日志文件->選擇第二個日志文件刪除->確定
再按上面說的刪除日志的方法去附加數據庫,就成功了
4: 如果想以后不讓它增長企業管理器--服務器--右鍵數據庫--屬性--事務日志--將文件增長限制為xM(x是你允許的最大數據文件大小) --SQL語句的設置方式:alter database 數據庫名 modify file(name=邏輯文件名,maxsize=20)5.設置為自動收縮企業管理器--服務器--右鍵數據庫--屬性--選項--選擇"自動收縮"
--還不行,就關閉用戶打開的進程處理,在查詢分析器中執行下面的語句
use master
go
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_killspid]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[p_killspid]
GO
create proc p_killspid
@dbname varchar(200) --要關閉進程的數據庫名
as
declare @sql nvarchar(500)
declare @spid nvarchar(20)
declare #tb cursor for
select spid=cast(spid as varchar(20)) from master..sysprocesses where dbid=db_id(@dbname)
open #tb
fetch next from #tb into @spid
while @@fetch_status=0
begin
exec('kill '+@spid)
fetch next from #tb into @spid
end
close #tb
deallocate #tb
go
--用法
exec p_killspid 'statmemberdata'
go
DBCC SHRINKDATABASE (statmemberdata)
go
drop proc p_killspid
刪除數據文件
dbcc shrinkfile (db_data2 , emptyfile)
alter database db
remove file db_data2
go
參考鏈接:
http://support.microsoft.com/?kbid=814579
http://www.experts-exchange.com/Databases/Microsoft_SQL_Server/Q_21090815.html
http://support.microsoft.com/default.aspx?scid=kb;zh-cn;317375
http://www.weste.net/html/200409/20040904QBI110037.html
http://www.knowsky.com/18746.html
?