最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

丢失或损坏NDF文件如何附加数据库

来源:动视网 责编:小采 时间:2020-11-09 07:22:59
文档

丢失或损坏NDF文件如何附加数据库

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


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

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

但是访问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 也是可以成功附加的。但是有条件,丢失的 NDF 文件不属于 Primary file group
推荐度:
标签: 丢失 文件 数据库
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top