本文主要向大家介绍了SQLServer数据库之Sql Server 逻辑文件 '' 不是数据库 '' 的一部分。请使用 RESTORE FILELISTONLY 来列出逻辑文件名。,通过具体的内容向大家展现,希望对大家学习SQLServer数据库有所帮助。
当使用语句还原数据库时,报如下错误:
消息 3234,级别 16,状态 2,第 29 行逻辑文件 ‘LenborMealOrder_Base_2017‘ 不是数据库 ‘Members_01‘ 的一部分。请使用 RESTORE FILELISTONLY 来列出逻辑文件名。消息 3013,级别 16,状态 1,第 29 行RESTORE DATABASE 正在异常终止。
原因:此数据库是用sql语句备份而来,引发的错误,原备份和还原的sql语句如下:
--备份
BACKUP DATABASE LeaRunFramework_Base_2016 TO DISK = ‘c:\DB_BACKUP\LenborMealOrder_Base_2017.bak‘
--还原
RESTORE DATABASE Members_01 FROM DISK = ‘c:\DB_BACKUP\LenborMealOrder_Base_2017.bak‘
WITH MOVE ‘LenborMealOrder_Base_2017‘ TO ‘c:\DB_BACKUP\Members_01.mdf‘,
MOVE ‘LenborMealOrder_Base_2017_log‘ TO ‘c:\DB_BACKUP\Members_01.ldf‘
解决方案:查找该数据的逻辑文件名,通过下面的语句即可查出,再修改还原语句中的名称即可。
--获得数据库备份文件的信息
restore filelistonly from disk=‘c:\DB_BACKUP\LenborMealOrder_Base_2017.bak‘
修改后的还原语句如下:
--还原
RESTORE DATABASE LenborMealOrder_Base_2017 FROM DISK = ‘c:\DB_BACKUP\LenborMealOrder_Base.bak‘
WITH MOVE ‘LeaRunFramework_Base_2016‘ TO ‘c:\DB_BACKUP\LenborMealOrder_Base_2017.mdf‘,
MOVE ‘LeaRunFramework_Base_2016_log‘ TO ‘c:\DB_BACKUP\LenborMealOrder_Base_2017.ldf‘
执行上述语句即成功还原数据库,如下图:
本文由职坐标整理并发布,希望对同学们学习SQL Server有所帮助,更多内容请关注职坐标数据库SQL Server数据库频道!