当前位置: 首页 > 工具软件 > ndf > 使用案例 >

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

萧玮
2023-12-01

在论坛看到有人遇到NDF文件丢失并且没有备份,所以无法成功附加数据库。在网上也看到过很多回答是如果没有NDF就无法附加成功。

其实我自己测试下来即使没有NDF也是可以成功附加的。但是有条件,丢失的NDF文件不属于Primary file group并且SQL Server为企业版

下面是我做的测试:

1.--创建数据库

CREATEDATABASE[test1]CONTAINMENT=NONEONPRIMARY

(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%)

GO

2.--在primary file group上创建两张表

createtabletest(namevarchar(10))ON[PRIMARY]

createtabletest2(namevarchar(10))ON[PRIMARY]

--在NDF上面创建一张表

createtabletest1(namevarchar(10))onnew

3.--插入10条数据

insertintotestvalues('kevin')

go 10

insertintotest1values('kevin')

go 10

insertintotest2values('kevin')

go 10

4.--Detach数据库

USE[master]

GO

EXECmaster.dbo.sp_detach_db@dbname=N'test1'

GO

5.       将MDF,NDF,LDF文件复制到其他文件夹

6.按照第一步的脚步创建一个同名的数据库

--将数据库Offline

usemaster

go

alterdatabasetest1setoffline

7.将第5步备份的MDF和LDF文件覆盖现在的数据库MDF和LDF

8.将出问题的NDF文件Offline

alterdatabasetest1modifyFILE(name=new,offline)

9.将数据库Online

alterdatabasetest1setonline

现在可以看到三张表都是存在的,但是访问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是离线的,所以无法访问。

 类似资料: