丢失或损坏NDF文件如何附加数据库 推荐
2013-08-07 14:07
302 查看
在论坛看到有人遇到 NDF文件丢失并且没有备份,所以无法成功附加数据库。在网上也看到过很多回答是如果没有NDF就无法附加成功。
其实我自己测试下来即使没有NDF也是可以成功附加的。但是有条件,丢失的NDF文件不属于Primary file group并且SQL Server为企业版
下面是我做的测试:
1. --创建数据库CREATE DATABASE [test1] CONTAINMENT=NONE ONPRIMARY(NAME=N'test1',FILENAME=N'C:\data\test1.mdf',SIZE= 5120KB,MAXSIZE=UNLIMITED,FILEGROWTH= 1024KB),FILEGROUP[New](NAME=N'new',FILENAME=N'C:\data\new.ndf',SIZE= 5120KB,MAXSIZE=UNLIMITED,FILEGROWTH= 1024KB)LOGON(NAME=N'test1_log',FILENAME=N'C:\data\test1_log.ldf',SIZE= 1024KB,MAXSIZE= 2048GB,FILEGROWTH= 10%)GO2. --在primary file group上创建两张表 create table test(namevarchar(10))ON[PRIMARY]create table test2(namevarchar(10))ON[PRIMARY]--在NDF上面创建一张表create table test1(namevarchar(10))onnew 3. --插入10条数据insert into test values ('kevin')go 10insert into test1values ('kevin')go 10insert into test2 values ('kevin')go 10 4. --Detach数据库 USE[master]GOEXEC master.dbo.sp_detach_db@dbname=N'test1'GO 5. 将MDF,NDF,LDF文件复制到其他文件夹 6. 按照第一步的脚步创建一个同名的数据库 --将数据库Offlineusemastergoalter database test1 set offline 7.将第5步备份的MDF和LDF文件覆盖现在的数据库MDF和LDF
8.将出问题的NDF文件Offline
alter database test1 modify FILE (name=new,offline)
9.将数据库Online
alter database test1 set online
现在可以看到三张表都是存在的,但是访问test1表的时候会出现下面的错误:
Msg 8653,Level 16, State 1, Line 1The queryprocessor is unable to produce a plan for the table or view 'test1' because thetable resides in a filegroup which is not online.
因为表所在的Filegroup是离线的,所以无法访问。
其实我自己测试下来即使没有NDF也是可以成功附加的。但是有条件,丢失的NDF文件不属于Primary file group并且SQL Server为企业版
下面是我做的测试:
1. --创建数据库CREATE DATABASE [test1] CONTAINMENT=NONE ONPRIMARY(NAME=N'test1',FILENAME=N'C:\data\test1.mdf',SIZE= 5120KB,MAXSIZE=UNLIMITED,FILEGROWTH= 1024KB),FILEGROUP[New](NAME=N'new',FILENAME=N'C:\data\new.ndf',SIZE= 5120KB,MAXSIZE=UNLIMITED,FILEGROWTH= 1024KB)LOGON(NAME=N'test1_log',FILENAME=N'C:\data\test1_log.ldf',SIZE= 1024KB,MAXSIZE= 2048GB,FILEGROWTH= 10%)GO2. --在primary file group上创建两张表 create table test(namevarchar(10))ON[PRIMARY]create table test2(namevarchar(10))ON[PRIMARY]--在NDF上面创建一张表create table test1(namevarchar(10))onnew 3. --插入10条数据insert into test values ('kevin')go 10insert into test1values ('kevin')go 10insert into test2 values ('kevin')go 10 4. --Detach数据库 USE[master]GOEXEC master.dbo.sp_detach_db@dbname=N'test1'GO 5. 将MDF,NDF,LDF文件复制到其他文件夹 6. 按照第一步的脚步创建一个同名的数据库 --将数据库Offlineusemastergoalter database test1 set offline 7.将第5步备份的MDF和LDF文件覆盖现在的数据库MDF和LDF
8.将出问题的NDF文件Offline
alter database test1 modify FILE (name=new,offline)
9.将数据库Online
alter database test1 set online
现在可以看到三张表都是存在的,但是访问test1表的时候会出现下面的错误:
Msg 8653,Level 16, State 1, Line 1The queryprocessor is unable to produce a plan for the table or view 'test1' because thetable resides in a filegroup which is not online.
因为表所在的Filegroup是离线的,所以无法访问。
相关文章推荐
- 丢失或损坏NDF文件如何附加数据库
- 丢失或损坏NDF文件如何附加数据库
- NDF文件丢失或者损坏是否可以成功附加数据库
- NDF文件丢失或者损坏是否可以成功附加数据库
- 附加数据库的时候,发现丢失.ndf文件,只有mdf和ldf文件。。。杯具
- sql server 2000,Log.LDF文件丢失,附加数据库失败的解决办法[转]
- LDF文件丢失, 如何仅用MDF文件恢复数据库呢?
- SQL Server 2005数据库日志文件损坏的情况下如何恢复数据库
- SQL Server 2005数据库日志文件损坏的情况下如何恢复数据库
- 如何修复“Windows/System32/Config/System中文件丢失或损坏”故障
- ASP.NET附加数据库文件的方式,如何发布到IIS7而不导致SQLServer出错
- 数据库没有备份---应如何还原丢失的数据 推荐
- 如果你的数据库文件只剩下数据文件没有日志文件时,如何附加
- Oracle 重建控制文件(在丢失控制文件的情况下,如何恢复数据库)
- 如何附加没有日志文件的数据库?
- 关于SQL数据库丢失.LDF文件后附加数据库的方法
- 仅有MDF和LDF文件如何还原数据库,以及附加失败解决办法
- sql server 2000 日志文件丢失,附加数据库失败的解决办法
- 教你一招超级简单的方法快速搞定grub.conf文件的丢失及损坏 推荐
- 主数据文件损坏(或丢失)情况下,如何备份尾部事务日志.