<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    如何數據庫收縮日志文件

    我有個數據庫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

    ?







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

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

    導航

    統計

    常用鏈接

    留言簿(8)

    隨筆分類(40)

    隨筆檔案(40)

    文章分類(33)

    文章檔案(34)

    相冊

    BLOG 聯盟

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 一边摸一边桶一边脱免费视频| 美女视频黄a视频全免费网站色窝 美女被cao网站免费看在线看 | 在线A级毛片无码免费真人| 久久狠狠高潮亚洲精品| 久久永久免费人妻精品下载| 一区二区三区亚洲| 足恋玩丝袜脚视频免费网站| 亚洲精品国产第1页| 一区二区三区四区免费视频 | 国产成人免费手机在线观看视频| 亚洲Aⅴ无码一区二区二三区软件 亚洲AⅤ视频一区二区三区 | 精品无码一区二区三区亚洲桃色| 亚洲日韩中文字幕一区| 全免费a级毛片免费看不卡| 亚洲精品综合在线影院| 女人张开腿给人桶免费视频 | 亚洲免费在线视频观看| 99久久精品日本一区二区免费| 免费看一级做a爰片久久| 国产亚洲综合久久| 久久精品国产亚洲精品| 国产色无码精品视频免费| 亚洲人成在线观看| 成人性生免费视频| 一级做a爰片性色毛片免费网站| 男女超爽刺激视频免费播放| 激情五月亚洲色图| 又大又硬又爽免费视频| 国产中文字幕在线免费观看| 亚洲大香人伊一本线| 国产精品无码素人福利免费| 一级一级一片免费高清| 亚洲黄网站wwwwww| 免费永久国产在线视频| 暖暖日本免费中文字幕| 亚洲中文字幕无码久久2020| 久久精品国产亚洲一区二区三区| 免费激情网站国产高清第一页| 四虎成人免费观看在线网址| 成年网在线观看免费观看网址| 国产午夜无码视频免费网站 |