怎樣壓縮數據庫的日誌文件
具體方法有3種。
方法一:
第一步:
backup log database_name with no_log
點擊下載“嗨格式壓縮大師”;
或者 backup log database_name with truncate_only
-- no_log和truncate_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:mssqldatayourDBName_data.mdf '
--以單文件的方式註冊該DB,如果成功則MSSQL將自動爲這個DB生成一個500K的日誌文件。
方法三:
1. 進入企業管理器,選中數據庫,比如demo
2. 所有任務->分離數據庫
3. 到數據庫文件的存放目錄,將MuOnline_log.LDF文件刪除,以防萬一,你可以拷出去
4. 企業管理器->附加數據庫,選muonline,這個時候你會看見日誌文件這項是一個叉,不要緊,繼續,此時數據庫就會提示你該數據庫無日誌是否創建一個新的,確定就是了。
5. 記得數據庫重新附加後用戶要重新設置一下。
如果以後,不想要它變大:
SQL2000下使用:
在數據庫上點右鍵->屬性->選項->故障恢復-模型-選擇-簡單模型。
或用SQL語句:
alter database 數據庫名 set recovery simple
SQL數據庫太大怎麼辦
--1.日常要做數據庫壓縮
--壓縮日誌及數據庫文件大小
/*--特別注意
請按步驟進行,未進行前面的步驟,請不要做後面的步驟
否則可能損壞你的數據庫.
--*/
1.清空日誌
DUMP TRANSACTION 庫名 WITH NO_LOG
2.截斷事務日誌:
BACKUP LOG 數據庫名 WITH NO_LOG
3.收縮數據庫文件(如果不壓縮,數據庫的文件不會減小
企業管理器--右鍵你要壓縮的數據庫--所有任務--收縮數據庫--收縮文件
--選擇日誌文件--在收縮方式裏選擇收縮至XXM,這裏會給出一個允許收縮到的最小M數,直接輸入這個數,確定就可以了
--選擇數據文件--在收縮方式裏選擇收縮至XXM,這裏會給出一個允許收縮到的最小M數,直接輸入這個數,確定就可以了
也可以用SQL語句來完成
--收縮數據庫
DBCC SHRINKDATABASE(客戶資料)
--收縮指定數據文件,1是文件號,可以通過這個語句查詢到:select * from sysfiles
DBCC SHRINKFILE(1)
4.爲了最大化的縮小日誌文件(如果是sql 7.0,這步只能在查詢分析器中進行)
a.分離數據庫:
企業管理器--服務器--數據庫--右鍵--分離數據庫
b.在我的電腦中刪除LOG文件
c.附加數據庫:
企業管理器--服務器--數據庫--右鍵--附加數據庫
此法將生成新的LOG,大小隻有500多K
或用代碼:
下面的示例分離 pubs,然後將 pubs 中的一個文件附加到當前服務器。
a.分離
EXEC sp_detach_db @dbname = 'pubs'
b.刪除日誌文件
c.再附加
EXEC sp_attach_single_file_db @dbname = 'pubs',
@physname = 'c:Program FilesMicrosoft SQL ServerMSSQLDatapubs.mdf'
5.爲了以後能自動收縮,做如下設置:
企業管理器--服務器--右鍵數據庫--屬性--選項--選擇"自動收縮"
--SQL語句設置方式:
EXEC sp_dboption '數據庫名', 'autoshrink', 'TRUE'
6.如果想以後不讓它日誌增長得太大
企業管理器--服務器--右鍵數據庫--屬性--事務日誌
--將文件增長限制爲xM(x是你允許的最大數據文件大小)
--SQL語句的設置方式:
alter database 數據庫名 modify file(name=邏輯文件名,maxsize=20)
以上就是數據庫日誌文件壓縮的方法及步驟的詳細內容,更多請關注本站其它相關文章!