sql2005-sqlserver 2012附加單個(gè)mdf數(shù)據(jù)文件(還原mdf文件),沒有日志文件
廣告:
sql2005附加單個(gè)mdf數(shù)據(jù)文件,沒有日志文件
一.刪除ldf文件附加
二.命令方法
我把原來(lái)的數(shù)據(jù)庫(kù)分離后,直接把日志文件給干掉了。原來(lái)在SQL 2000里經(jīng)常這么干,只用一個(gè)mdf就附加了。沒想到sql2005居然不行。我試驗(yàn)了一圈 終于找到一個(gè)成功的方法。轉(zhuǎn)載,供后來(lái)者參考。
SQL2005 如何在沒有日志文件的情況下如何恢復(fù)MDF數(shù)據(jù)庫(kù)文件
第一步:先建立一個(gè)同名數(shù)據(jù)庫(kù),停止SQL SERVER2005,將沒有日志的的.mdf數(shù)據(jù)庫(kù)文件覆蓋剛新建的.mdf數(shù)據(jù)庫(kù)文件,重新啟動(dòng)數(shù)據(jù)庫(kù)。
第三步:在查詢分析器中運(yùn)行如下代碼:
alter database LittleItalyVineyard set emergency --將數(shù)據(jù)庫(kù)設(shè)置為緊急狀態(tài) use master declare @databasename varchar(255) set @databasename='LittleItalyVineyard' --你的.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í)行一次即可。
上面代碼sql server 2012 r2會(huì)提示:找不到存儲(chǔ)過程 sp_dboption
2005:exec sp_dboption @databasename, N’single‘, N’true’ —將目標(biāo)數(shù)據(jù)庫(kù)置為單用戶狀態(tài)
2012:ALTER DATABASE @databasename SET SINGLE_USER WITH ROLLBACK IMMEDIATE; --把數(shù)據(jù)設(shè)為單用戶模式
sql server 2012 r2代碼:
alter database test set emergency --將數(shù)據(jù)庫(kù)設(shè)置為緊急狀態(tài) alter database test set emergency --將數(shù)據(jù)庫(kù)設(shè)置為緊急狀態(tài) use master ALTER DATABASE test SET SINGLE_USER WITH ROLLBACK IMMEDIATE go --將目標(biāo)數(shù)據(jù)庫(kù)置為單用戶狀態(tài) dbcc checkdb(test,REPAIR_ALLOW_DATA_LOSS) dbcc checkdb(test,REPAIR_REBUILD) go ALTER DATABASE test SET MULTI_USER --將目標(biāo)數(shù)據(jù)庫(kù)置為多用戶狀態(tài)
三. sqlserver 2012 r2 測(cè)試這個(gè)方法有效
以下方法 sqlserver 2019/ sqlserver 2008 r2 mdf同目錄下面會(huì)自動(dòng)生成ldf
CREATE DATABASE 新數(shù)據(jù)庫(kù)名稱 ON ( FILENAME ='E:\asp.net電子商務(wù)編程(C#)2005\Database\MDF File\LittleItalyVineyard.mdf' ) for ATTACH_REBUILD_LOG
附加mdf+ndf,以下自動(dòng)生成日志
EXEC sp_attach_db @dbname = N'Esautocrm_810SP2_HKZC', @filename1 = N'K:\temp\20250415-300\20250416\Esautocrm_810SP2_HKZC.MDF', @filename2 = N'K:\temp\20250415-300\20250416\Esautocrm_810SP2_HKZC_1.ndf';
損壞修復(fù)日成:
ALTER DATABASE opacs REBUILD LOG ON (NAME=日志邏輯名, FILENAME='新日志路徑.ldf')
廣告:


