|
序:
MS SQL Server 2008 r2附加無ldf日志的mdf數(shù)據(jù)庫時(shí)報(bào)1813錯(cuò)誤。提示數(shù)據(jù)庫被強(qiáng)制分離,無日志不能還原之類的話。
原因:
原因系統(tǒng)正在執(zhí)行定時(shí)作業(yè),沒有主要到多次強(qiáng)制分離了數(shù)據(jù)庫。當(dāng)附加回mdf文件時(shí)報(bào)錯(cuò)誤1813。總之都是手賤惹的禍。。。
解決辦法:
1、首先要備份好mdf文件,如果他沒了經(jīng)理非吃了你不可。都不吐骨頭的。
2、在數(shù)據(jù)庫中新建一個(gè)需要附加同名的數(shù)據(jù)庫。例如【testdb】
3、停止SQL Server服務(wù)
4、找到該數(shù)據(jù)庫所在的文件夾、并刪除testdb_log.ldf與testdb.mdf文件
5、 把需要附加的數(shù)據(jù)庫【testdb.mdf】文件拷貝到當(dāng)前路徑。
6、啟動(dòng)SQL Server服務(wù),通過企業(yè)管理器連接數(shù)據(jù)庫。
7、此時(shí)的1步中新建的數(shù)據(jù)庫地址已經(jīng)指向你需要附加數(shù)據(jù)庫的mdf文件了。但是現(xiàn)在數(shù)據(jù)庫還是無法打開的。
8、執(zhí)行語句:ALTER DATABASE testdb SET EMERGENCY
9、執(zhí)行語句:ALTER DATABASE testdb SET SINGLE_USER
10、執(zhí)行語句:ALTER DATABASE testdb REBUILD LOG ON (NAME=dbname_log, FILENAME='C:\XXX\dbname_log.ldf')
其中FILENAME為你需要新建ldf日志的路徑已經(jīng)ldf文件名稱。運(yùn)行后會(huì)出現(xiàn)一條警告“執(zhí)行后,會(huì)有警告信息“警告: 數(shù)據(jù)庫 'xhtyjbbs' 的日志已重新生成。已失去事務(wù)的一致性。RESTORE 鏈已斷開,服務(wù)器不再有以前的日志文件的上下文,因此您需要了解它們的內(nèi)容。應(yīng)運(yùn)行 DBCC CHECKDB 驗(yàn)證物理一致性。數(shù)據(jù)庫已置于 dbo-only 模式。在準(zhǔn)備使數(shù)據(jù)庫可用時(shí),需要重置數(shù)據(jù)庫選項(xiàng),并刪除所有多余的日志文件。””別鳥他。
11、 DBCC CHECKDB(testdb , REPAIR_ALLOW_DATA_LOSS) 這一步會(huì)比較卡,可能會(huì)導(dǎo)致界面未響應(yīng)。多等一會(huì)。成功后數(shù)據(jù)庫變成了單用戶模式,下面兩步驟修改成多用戶模式。
12、ALTER DATABASE testdb SET MULTI_USER
13、ALTER DATABASE testdb SET ONLINE
尾:
不出意外的話數(shù)據(jù)庫應(yīng)該可以使用。
|
|