SQL Server 在缺少文件组的情况下如何还原数据库

一、背景

SQL Server 维护计划备份主分区 和 主分区备份与还原),为了对a,b表进新的数据,我修改了a,b表名,在B库新建了两张不分区的a,b表;

这样运行都没有什么问题的,但是在一次我分离了数据库B,拷贝了mdf和ldf文件,现在想使用mdf和ldf还原为B库的时候出错了;

 

二、解决过程

  在使用SSMS的还原功能进行还原的时候出现了下面的错误:

SQL Server 数据源是存在哪里的_SQL

(图1:找不到文件组)

SQL Server 数据源是存在哪里的_Server_02

(图2:手动创建一个ndf文件报错)

  在还原的时候需要指定ndf文件的目录,但是由于在备份的时候我们只备份了主文件,所以是没有ndf文件的(注意:表结构是在主文件组的,所以这里会显示ndf文件信息),这个时候想通过删除列表中ndf,却发现删除按钮不可用,如图1所示;

  在对应的目录中手动创建一个ndf文件,出现了图2的错误,因为无法读取到文件头;

  难道就无法还原数据库B了嘛?不要着急,我们把上面的操作生成SQL代码,把不需要的ndf文件删除掉,剩下类似下面的SQL代码,执行,还原了数据库B!


SQL Server 数据源是存在哪里的_Server_03



USE [master]
GO
CREATE DATABASE [QQMonitor] ON 
( FILENAME = N'E:\DBBackup\DBName.mdf' ),
( FILENAME = N'E:\DBBackup\DBName_log.ldf' )
 FOR ATTACH
GO



SQL Server 数据源是存在哪里的_Server_03


  或者自己直接写代码,例如以下的代码:


SQL Server 数据源是存在哪里的_Server_03



--还原主分区
RESTORE DATABASE [TestAnt]
FILEGROUP='PRIMARY'
FROM DISK='F:\DBBackup\Ant_Primary\Ant_Primary_20110916000001.bak' WITH FILE = 1,
MOVE N'Barefoot.Ant' TO N'F:\DBBackup\TestAnt.mdf',
MOVE N'Barefoot.Ant_log' TO N'F:\DBBackup\TestAnt_log.ldf',
RECOVERY,REPLACE,  STATS = 10
GO



SQL Server 数据源是存在哪里的_Server_03