设想情况:
abc.bak)G:\SQLDB\backup\master_copy.bak使用的:
RESTORE DATABASE New_DB
FROM DISK = 'G:\SQLDB\backup\master_copy.bak'
WITH
MOVE 'coop_test_dat' TO 'G:\SQLDB\livedb\new_db_data.mdf',
MOVE 'coop_test_log' TO 'G:\SQLDB\livedb\new_db_log.ldf',
REPLACE产生的错误:
Msg 5133,第16级,状态1,第1行 由于操作系统错误3(系统找不到指定的路径),文件"C:\SQLDB\masterdb\master_blank.mdf“的目录查找失败。 Msg 3156,16级,状态3,第1行 文件'coop_demo‘不能还原到’C:\SQLDB\master to \master_blank.mdf‘。使用“移动”标识文件的有效位置。
在这里,给定的指定路径来自旧机器,而旧机器在新机器中不存在。
我怎么才能解决这个问题?
发布于 2017-07-25 15:08:44
Jeroen的建议是,您可能缺少一些files..so来查看以下命令中使用的所有文件。
restore filelistonly from disk ='your .bak path' with file=1上述命令的输出将显示备份的所有文件,然后可以使用restore with替换
因此,如果还原文件列表如下所示为逻辑文件名
logicalname
db_Data
db_Data1
db_log现在你可以用
RESTORE DATABASE New_DB
FROM DISK = 'G:\SQLDB\backup\master_copy.bak' WITH
MOVE 'db_Data' TO 'G:\SQLDB\livedb\new_db_data.mdf',
MOVE 'db_Data1' TO 'G:\SQLDB\livedb\new_db_data1.ndf',
MOVE 'db_lof TO 'G:\SQLDB\livedb\new_db_log.log',
REPLACEhttps://stackoverflow.com/questions/45306941
复制相似问题