數(shù)據(jù)庫在使用中,冗余的數(shù)據(jù)不斷的增加(數(shù)據(jù)刪除也不會減小),導(dǎo)致數(shù)據(jù)庫不斷的增大!所以該給你的數(shù)據(jù)庫減減肥了
Access
操作很簡單,具體不步驟如下:打開你mdb數(shù)據(jù)庫,工具-->數(shù)據(jù)庫實用工具-->壓縮和修復(fù)數(shù)據(jù)庫(c)…
SQL SERVER
一般情況下,SQL數(shù)據(jù)庫的收縮并不能很大程度上減小數(shù)據(jù)庫大小,其主要作用是收縮日志大小,應(yīng)當(dāng)定期進(jìn)行此操作以免數(shù)據(jù)庫日志過大
1、設(shè)置數(shù)據(jù)庫模式為簡單模式:打開SQL企業(yè)管理器,在控制臺根目錄中依次點開Microsoft SQLServer–>SQLServer組–>雙擊打開你的服務(wù)器–>雙擊打開數(shù)據(jù)庫目錄–>選擇你的數(shù)據(jù)庫名稱(如論壇數(shù)據(jù)庫Forum)–>然后點擊右鍵選擇屬性–>選擇選項–>在故障還原的模式中選擇”簡單”,然后按確定保存
2、在當(dāng)前數(shù)據(jù)庫上點右鍵,看所有任務(wù)中的收縮數(shù)據(jù)庫,一般里面的默認(rèn)設(shè)置不用調(diào)整,直接點確定
3、收縮數(shù)據(jù)庫完成后,建議將您的數(shù)據(jù)庫屬性重新設(shè)置為標(biāo)準(zhǔn)模式,操作方法同第一點,因為日志在一些異常情況下往往是恢復(fù)數(shù)據(jù)庫的重要依據(jù)
不過服務(wù)器上可以用下面的語句在查詢分析器中執(zhí)行
代碼如下:
DUMP TRANSACTION [jc8] WITH NO_LOG
BACKUP LOG [jc8] WITH NO_LOG
DBCC SHRINKDATABASE([jc8])
jc8為數(shù)據(jù)庫名,來實現(xiàn)jc8.ldf文件的清理。
SQLServer事務(wù)日志壓縮與刪除
問:SQLServer中的事務(wù)日志應(yīng)該怎樣壓縮和刪除?
答:具體方法有3種。
方法一:
第一步:
backup log database_name with no_log
或者 backup log database_name with truncate_only
— no_log和truncate_only是在這里是同義的,隨便執(zhí)行哪一句都可以。
第二步:
1.收縮特定數(shù)據(jù)庫的所有數(shù)據(jù)和日志文件,執(zhí)行:
dbcc shrinkdatabase (database_name,[,target_percent])
— database_name是要收縮的數(shù)據(jù)庫名稱;target_percent是數(shù)據(jù)庫收縮后的數(shù)據(jù)庫文件中所要的剩余可用空間百分比。
2.收縮一次一個特定數(shù)據(jù)庫中的數(shù)據(jù)或日志文件,執(zhí)行
dbcc shrinkfile(file_id,[,target_size])
— file_id是要收縮的文件的標(biāo)識 (ID) 號,若要獲得文件 ID,請使用 FILE_ID 函數(shù)或在當(dāng)前數(shù)據(jù)庫中搜索 sysfiles;target_size是用兆字節(jié)表示的所要的文件大小(用整數(shù)表示)。如果沒有指定,dbcc shrinkfile 將文件大小減少到默認(rèn)文件大小。兩個dbcc都可以帶上參數(shù)notruncate或truncateonly,具體意思查看聯(lián)機(jī)幫助.
方法二:
第一步:
先備份整個數(shù)據(jù)庫以備不測 。
第二步:
備份結(jié)束后,在Query Analyzer中執(zhí)行如下的語句:
exec sp_detach_db yourDBName,true
–卸除這個DB在MSSQL中的注冊信息
第三步:
到日志的物理文件所在的目錄中去刪除該日志文件或者將該日志文件移出該目錄
第四步:
在Query Analyzer中執(zhí)行如下的語句:
exec sp_attach_single_file_db yourDBName,’
d:mssqldatayourDBName_data.mdf ‘
–以單文件的方式注冊該DB,如果成功則MSSQL將自動為這個DB生成一個500K的日志文件。
方法三:
1. 進(jìn)入企業(yè)管理器,選中數(shù)據(jù)庫,比如demo
2. 所有任務(wù)->分離數(shù)據(jù)庫
3. 到數(shù)據(jù)庫文件的存放目錄,將MuOnline_log.LDF文件刪除,以防萬一,你可以拷出去
4. 企業(yè)管理器->附加數(shù)據(jù)庫,選muonline,這個時候你會看見日志文件這項是一個叉,不要緊,繼續(xù),此時數(shù)據(jù)庫就會提示你該數(shù)據(jù)庫無日志是否創(chuàng)建一個新的,確定就是了。
5. 記得數(shù)據(jù)庫重新附加后用戶要重新設(shè)置一下。
如果以后,不想要它變大:
SQL2000下使用:
在數(shù)據(jù)庫上點右鍵->屬性->選項->故障恢復(fù)-模型-選擇-簡單模型。
或用SQL語句:
alter database 數(shù)據(jù)庫名 set recovery simple