如何數(shù)據(jù)庫收縮日志文件

          我有個數(shù)據(jù)庫statmemberdata現(xiàn)在的日志文件都達到40G了,我要用DBCC SHRINKDATABASE來收縮這個日志,過程如下:
          1、重新啟動數(shù)據(jù)服務器(通過遠程控制軟件進行的)
          2、在遠程通過SQL SERVER的查詢分析器中連接到數(shù)據(jù)服務器
          3、遠程控制數(shù)據(jù)服務器服務暫停
          4、過十分鐘,在遠程查詢分析器中執(zhí)行:
          ?? DBCC SHRINKDATABASE (statmemberdata)
          ?? 過了幾分鐘出現(xiàn)以下錯誤:
          ?? “無法收縮日志文件 2(statmemberdata_log),因為所有的邏輯日志文件都在使用。

          (所影響的行數(shù)為 2 行)

          DBCC 執(zhí)行完畢。如果 DBCC 輸出了錯誤信息,請與系統(tǒng)管理員聯(lián)系?!?br />
          我不明白了,我都重新啟動了數(shù)據(jù)服務器,啟動完后馬上有暫停了sql server的服務,然后又過了一段時間才運行DBCC SHRINKDATABASE的,怎么老是說“所有的邏輯日志文件都在使用”呢,都試過好多次了,都是這樣。

          ----------------------------------------------------------------------------------------------------------------

          1: 刪除LOG
          1:分離數(shù)據(jù)庫?? 企業(yè)管理器->服務器->數(shù)據(jù)庫->右鍵->分離數(shù)據(jù)庫
          2:刪除LOG文件
          3:附加數(shù)據(jù)庫? 企業(yè)管理器->服務器->數(shù)據(jù)庫->右鍵->附加數(shù)據(jù)庫
          此法生成新的LOG,大小只有500多K
          ?? 再將此數(shù)據(jù)庫設(shè)置自動收縮
          或用代碼:
          下面的示例分離 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???

          再:
          企業(yè)管理器--右鍵你要壓縮的數(shù)據(jù)庫--所有任務--收縮數(shù)據(jù)庫--收縮文件--選擇日志文件--在收縮方式里選擇收縮至XXM,這里會給出一個允許收縮到的最小M數(shù),直接輸入這個數(shù),確定就可以了

          3: 如果想以后不讓它增長
          企業(yè)管理器->服務器->數(shù)據(jù)庫->屬性->事務日志->將文件增長限制為2M

          				--壓縮日志
          
          1:截斷事務日志:
          BACKUP LOG 數(shù)據(jù)庫名 WITH NO_LOG
          
          2:清空日志
          DUMP  TRANSACTION  庫名  WITH  NO_LOG    
          
          再:
          企業(yè)管理器--右鍵你要壓縮的數(shù)據(jù)庫--所有任務--收縮數(shù)據(jù)庫--收縮文件--選擇日志文件--在收縮方式里選擇收縮至XXM,這里會給出一個允許收縮到的最小M數(shù),直接輸入這個數(shù),確定就可以了
          
          
          3: 刪除LOG
          	1:分離數(shù)據(jù)庫   企業(yè)管理器->服務器->數(shù)據(jù)庫->右鍵->分離數(shù)據(jù)庫
          	2:刪除LOG文件
          	3:附加數(shù)據(jù)庫  企業(yè)管理器->服務器->數(shù)據(jù)庫->右鍵->附加數(shù)據(jù)庫
          	此法生成新的LOG,大小只有500多K
             再將此數(shù)據(jù)庫設(shè)置自動收縮
           或用代碼: 
          下面的示例分離 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'



          				對于有兩個庫文件的數(shù)據(jù)庫請用下面的語句:

          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'


          				如果數(shù)據(jù)庫有兩個日志文件,則以上方法就不行了。
          需要刪掉其中一個日志文件,方法如下:
          截斷事務日志: BACKUP LOG otsp WITH NO_LOG 清空日志 DUMP TRANSACTION otsp WITH NO_LOG ??
          刪除LOG文件 企業(yè)管理器->服務器->數(shù)據(jù)庫->右鍵->屬性->日志文件->選擇第二個日志文件刪除->確定

          再按上面說的刪除日志的方法去附加數(shù)據(jù)庫,就成功了
          4: 如果想以后不讓它增長企業(yè)管理器--服務器--右鍵數(shù)據(jù)庫--屬性--事務日志--將文件增長限制為xM(x是你允許的最大數(shù)據(jù)文件大小) --SQL語句的設(shè)置方式:alter database 數(shù)據(jù)庫名 modify file(name=邏輯文件名,maxsize=20)5.設(shè)置為自動收縮企業(yè)管理器--服務器--右鍵數(shù)據(jù)庫--屬性--選項--選擇"自動收縮"
          --還不行,就關(guān)閉用戶打開的進程處理,在查詢分析器中執(zhí)行下面的語句
          
          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)	--要關(guān)閉進程的數(shù)據(jù)庫名
          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
          









          刪除數(shù)據(jù)文件

          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

          ?







          posted on 2006-06-01 15:51 【Xine】中文站 閱讀(1909) 評論(0)  編輯  收藏 所屬分類: SQL Server

          <2025年5月>
          27282930123
          45678910
          11121314151617
          18192021222324
          25262728293031
          1234567

          導航

          統(tǒng)計

          常用鏈接

          留言簿(8)

          隨筆分類(40)

          隨筆檔案(40)

          文章分類(33)

          文章檔案(34)

          相冊

          BLOG 聯(lián)盟

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 乡宁县| 克什克腾旗| 吉木乃县| 东乡县| 神农架林区| 博罗县| 武城县| 东山县| 上犹县| 曲沃县| 玉屏| 灵丘县| 尼木县| 开封市| 朝阳区| 大悟县| 台东市| 朝阳县| 锦屏县| 昌吉市| 宁明县| 洛隆县| 保德县| 明光市| 辽中县| 盱眙县| 许昌市| 济南市| 仪陇县| 敦煌市| 太白县| 水城县| 广州市| 凭祥市| 桐梓县| 砀山县| 泽库县| 新丰县| 五寨县| 昂仁县| 新郑市|