ndf怎么导入mysql_丢失或损坏NDF文件如何附加数据库

在论坛看到有人遇到 NDF 文件丢失并且没有备份,所以无法成功附加数据库。在网上也看到过很多回答是如果没有 NDF 就无法附加成功。 其实我自己测试下来即使没有 NDF 也是可以成功附加的。但是有条件,丢失的 NDF 文件不属于 Primary file group 并且 SQL Ser

在论坛看到有人遇到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

现在可以看到三张表都是存在的

test.jsp?url=http%3A%2F%2Fimg.blog.csdn.net%2F20130807140526093%3Fwatermark%2F2%2Ftext%2FaHR0cDovL2Jsb2cuY3Nkbi5uZXQvU21pdGhMaXUzMjg%3D%2Ffont%2F5a6L5L2T%2Ffontsize%2F400%2Ffill%2FI0JBQkFCMA%3D%3D%2Fdissolve%2F70%2Fgravity%2FSouthEast&refer=http%3A%2F%2Fblog.csdn.net%2Fkevinsqlserver%2Farticle%2Fdetails%2F9816391

但是访问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是离线的,所以无法访问。

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值