我把原來(lái)的數(shù)據(jù)庫(kù)分離后,直接把日志文件給干掉了。原來(lái)在SQL 2000里經(jīng)常這么干,只用一個(gè)mdf就附加了。沒(méi)想到sql2005居然不行。我試驗(yàn)了一圈 終于找到一個(gè)成功的方法。轉(zhuǎn)載,供后來(lái)者參考。
SQL2000 簡(jiǎn)單一些
sp_configure 'allow updates',1
go
reconfigure with override
go
SQL2005 如果mdf不存在任何錯(cuò)誤可以使用這個(gè)方法:
SQL2005 如何在沒(méi)有日志文件的情況下如何恢復(fù)MDF數(shù)據(jù)庫(kù)文件
第一步:先建立一個(gè)同名數(shù)據(jù)庫(kù),停止SQL SERVER2005,將沒(méi)有日志的的.mdf數(shù)據(jù)庫(kù)文件覆蓋剛新建的.mdf數(shù)據(jù)庫(kù)文件,重新啟動(dòng)數(shù)據(jù)庫(kù)。
第三步:在查詢分析器中運(yùn)行如下代碼:
alter database 數(shù)據(jù)庫(kù)名 set emergency —將數(shù)據(jù)庫(kù)設(shè)置為緊急狀態(tài)
use master?
declare @databasename varchar(255)?
set @databasename=‘?dāng)?shù)據(jù)庫(kù)名’ —你的.mdf文件文件名
exec sp_dboption @databasename, N’single‘, N’true’ —將目標(biāo)數(shù)據(jù)庫(kù)置為單用戶狀態(tài)?
dbcc checkdb(@databasename,REPAIR_ALLOW_DATA_LOSS)?
dbcc checkdb(@databasename,REPAIR_REBUILD)?
exec sp_dboption @databasename, N’single‘, N’false’—將目標(biāo)數(shù)據(jù)庫(kù)置為多用戶狀態(tài)?
執(zhí)行出現(xiàn)“數(shù)據(jù)庫(kù)其他多個(gè)文件與數(shù)據(jù)庫(kù)主文件不匹配….”錯(cuò)誤,再執(zhí)行一次即可。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
