方法一:
第一步:
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是用MB表示的所要的檔案大小(用整數表示)。如果沒有指定,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. 到資料庫檔案的存放目錄,將MuOnline_log.LDF檔案刪除,以防萬一,你可以拷出去
4. 企業管理器->附加資料庫,選muonline,這個時候你會看見記錄檔這項是一個叉,不要緊,繼續,此時資料庫就會提示你該資料庫無日誌是否建立一個新的,確定就是了。
5. 記得資料庫重新附加後使用者要重新設定一下。
如果以後,不想要它變大:
SQL2000下使用:
在資料庫上點右鍵->屬性->選項->故障恢複-模型-選擇-簡單模型。
或用SQL語句:
alter database 資料庫名 set recovery simple