如何清除SQL server日志 81377318
懸賞分:0 - 解決時(shí)間:2006-4-13 17:43
如何清除SQL server log,會(huì )不會(huì )影響數據呀?
提問(wèn)者: slh888 - 經(jīng)理 四級
最佳答案
方法1:
第一步:
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是要收縮的數據庫名稱(chēng);target_percent是數據庫收縮后的數據庫文件中所要的剩余可用空間百分比
2.收縮一次一個(gè)特定數據庫中的數據或日志文件,執行 dbcc shrinkfile(file_id,[,target_size]) --file_id是要收縮的文件的標識 (ID) 號,若要獲得文件 ID,請使用 FILE_ID 函數或在當前數據庫中搜索 sysfiles;target_size是用兆字節表示的所要的文件大?。ㄓ谜麛当硎荆?。如果沒(méi)有指定,dbcc shrinkfile 將文件大小減少到默認文件大小
兩個(gè)dbcc都可以帶上參數notruncate或truncateonly,具體意思看幫助。
方法2
(這個(gè)方法在sqlserver2000的環(huán)境下做一般能成功,在sqlserver7及以下版本就不一定了):
第一步:
先備份整個(gè)數據庫以備不測
第二步:
備份結束后,在Query Analyzer中執行如下的語(yǔ)句:
exec sp_detach_db yourDBName,true --卸除這個(gè)DB在MSSQL中的注冊信息
第三步:
到日志的物理文件所在的目錄中去刪除該日志文件或者將該日志文件移出該目錄
第四步:
在Query Analyzer中執行如下的語(yǔ)句:
exec sp_attach_single_file_db yourDBName,‘d:\mssql7\data\yourDBName_data.mdf‘
--以單文件的方式注冊該DB,如果成功則MSSQL將自動(dòng)為這個(gè)DB生成一個(gè)500K的日志文件。
以上方法在清除log日志中均有效。
但,能否讓sql server 不產(chǎn)生log日志呢?以上方法好像均無(wú)效。
我這兒正好有個(gè)case:
我客戶(hù)的sql server每天都會(huì )產(chǎn)生4,500M的log日志,每天都清除一下,非常不便。有沒(méi)有辦法實(shí)現不產(chǎn)生log日志呢?
我分析了一下客戶(hù)產(chǎn)生log日志的原因,并且做了相應測試。
客戶(hù)是每天將數據庫清空,從總系統中將數據導入到sql server里。我感決sqlserver在插入時(shí)產(chǎn)生log不大,在delete整個(gè)庫時(shí)產(chǎn)生log極大。
比如:
SELECT * into test_2 from b_bgxx
共45000條記錄,產(chǎn)生十幾M log,如果
delete from test_2
產(chǎn)生80多M log ,這明顯存在問(wèn)題。
雖然可以換成:
truncate table test_2
但我還是希望能找到不產(chǎn)生log的方法。就如oracle不產(chǎn)生歸檔一樣。
聯(lián)系客服