丢失或损坏NDF文件如何附加数据库
2013-08-07 14:04
337 查看
在论坛看到有人遇到 NDF文件丢失并且没有备份,所以无法成功附加数据库。在网上也看到过很多回答是如果没有NDF就无法附加成功。
其实我自己测试下来即使没有NDF也是可以成功附加的。但是有条件,丢失的NDF文件不属于Primary file group并且SQL Server为企业版
下面是我做的测试:
1. --创建数据库
CREATE DATABASE[test1] CONTAINMENT=NONE
ON PRIMARY
( 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)
LOG
ON
( NAME=N'test1_log',FILENAME=
N'C:\data\test1_log.ldf',SIZE
= 1024KB,MAXSIZE
= 2048GB,FILEGROWTH
= 10%)
GO
2. --在primary file group上创建两张表
create tabletest(namevarchar(10)) ON[PRIMARY]
create tabletest2(namevarchar(10)) ON[PRIMARY]
--在NDF上面创建一张表
create tabletest1(namevarchar(10))onnew
3. --插入10条数据
insert intotestvalues
('kevin')
go 10
insert intotest1values
('kevin')
go 10
insert intotest2values
('kevin')
go 10
4. --Detach数据库
USE[master]
GO
EXEC master.dbo.sp_detach_db@dbname=N'test1'
GO
5. 将MDF,NDF,LDF文件复制到其他文件夹
6. 按照第一步的脚步创建一个同名的数据库
--将数据库Offline
use master
go
alter databasetest1set
offline
7. 将第5步备份的MDF和LDF文件覆盖现在的数据库MDF和LDF
8. 将出问题的NDF文件Offline
alter databasetest1modify
FILE (name=new
,offline)
9. 将数据库Online
alter databasetest1set
online
现在可以看到三张表都是存在的
但是访问test1表的时候会出现下面的错误:
Msg 8653,Level 16, State 1, Line 1
The 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文件。。。杯具
- SQLServer2005数据库日志文件损坏的情况下如何恢复数据库
- 如何修复“Windows/System32/Config/System中文件丢失或损坏”故障
- 问题8:如何在应用表空间中的数据文件损坏或者丢失的情况下进行恢复?
- 如何附加没有日志文件的数据库?
- 如果你的数据库文件只剩下数据文件没有日志文件时,如何附加 (摘自:http://www.cnblogs.com/yukaizhao/archive/2008/07/23/sp_attach_single_file_db.html)
- 如何合并数据库文件(合并多个ndf)
- 如何将附加文件存储在文件系统而不是数据库
- 如何恢复SQL Server 2000损坏的数据库文件
- SQL Server中如何附加没有ldf文件的数据库
- SQL Server 2005数据库日志文件损坏的情况下如何恢复数据库
- [转]sql server 2000,Log.LDF文件丢失,附加数据库失败的解决办法
- SQL Server 2005数据库日志文件损坏的情况下如何恢复数据库
- SQL Server 2005数据库日志文件损坏的情况下如何恢复数据库
- 如何在数据库文件损坏情况下,进行恢复
- 控制文件损坏或者丢失的Oracle 10g数据库恢复控制文件一例