解析SQLServer事務日志壓縮與刪除的方法


做項目的時候拿到一個只有280M的數據庫備份,可是在SQLServer 2000下恢復的時候等了半天才都沒有恢復完畢,感覺很不可思議,於是懷疑有什么貓膩。到了數據文件的目錄下一看,果不其然竟然聲稱了一個接近10G的數據庫日志文件!以前從來沒有做過那么多數據的數據庫,而且更沒有做過有3年數據庫日志記錄的數據庫。

    這對於硬盤空間不是很充裕的我來說已經超過了能夠忍受的極限,而且另一個80M的數據庫回復之后生成的日志文件更是誇張的達到了5G+!這是不能忍受的,也是不能被原諒的。
    剛開始的時候不太懂,直接把數據庫日志刪除了,發現這樣數據庫就不能用了,於是百度了一下,發現網上很多提到了日志的壓縮和刪除技術,正是我想要掌握的內容。仔細整理了一下,大致有這么幾種方法解決。
------------------------

方法一:  這是對數據庫和日志進行收縮,比較麻煩,也不是我想要的。

第一步: 

backup log database_name with no_log

或者 backup log database_name with truncate_only

no_logtruncate_only是在這里是同義的,隨便執行哪一句都可以。 

第二步: 

1.收縮特定數據庫的所有數據和日志文件,執行: 

dbcc shrinkdatabase (database_name,[,target_percent])

 database_name是要收縮的數據庫名稱;target_percent是數據庫收縮后的數據庫文件中所要的剩余可用空間百分比。

2.收縮一次一個特定數據庫中的數據或日志文件,執行

dbcc shrinkfile(file_id,[,target_size])

file_id是要收縮的文件的標識 (ID) 號,若要獲得文件 ID,請使用 FILE_ID 函數或在當前數據庫中搜索 sysfiles;target_size是用兆字節表示的所要的文件大小(用整數表示)。如果沒有指定,dbcc shrinkfile 將文件大小減少到默認文件大小。兩個dbcc都可以帶上參數notruncate或truncateonly,具體意思查看聯機幫助. 

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

方法二:  這個正是我想要的,刪除原來的日志文件。但是在操作的時候總是提示我數據庫正在使用當中,如果我停掉數據庫管理器有進不去企業管理器找到要收縮的數據庫,沒辦法只好放棄,改試第三種。

第一步: 

先備份整個數據庫以備不測 。 

第二步: 

備份結束后,在Query Analyzer中執行如下的語句: 

exec sp_detach_db yourDBName,true

卸除這個DB在MSSQL中的注冊信息 

第三步: 

到日志的物理文件所在的目錄中去刪除該日志文件或者將該日志文件移出該目錄

第四步: 

在Query Analyzer中執行如下的語句:

exec sp_attach_single_file_db yourDBName,'

d:\mssql\data\yourDBName_data.mdf '

以單文件的方式注冊該DB,如果成功則MSSQL將自動為這個DB生成一個500K的日志文件。 

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

方法三:  完美解決!

1. 進入企業管理器,選中數據庫,比如demo 

2. 所有任務->分離數據庫 

3. 到數據庫文件的存放目錄,將demo_log.LDF文件刪除,以防萬一,你可以拷出去,或者是給它改名

4. 企業管理器->附加數據庫,選demo,這個時候你會看見日志文件這項是一個叉,不要緊,繼續,此時數據庫就會提示你該數據庫無日志是否創建一個新的,確定就是了。 

5. 記得數據庫重新附加后用戶要重新設置一下。 

如果以后,不想要它變大: 

SQL2000下使用: 

在數據庫上點右鍵->屬性->選項->故障恢復-模型-選擇-簡單模型。 

或用SQL語句: 

alter database 數據庫名 set recovery simple

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

    第三種辦法完美解決了我的問題,真是令人愉快的一天啊!而且安裝好了數據庫之后很順利的能夠對項目進行部署了,希望接下來一切順利。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM