如何恢复/修复SQL Server的MDF文件

2016-01-29 15:49 7 1 收藏

如何恢复/修复SQL Server的MDF文件,如何恢复/修复SQL Server的MDF文件

【 tulaoshi.com - SQLServer 】

如果备份的数据库有2个文件,分别是.LDF 和 .MDF,打开企业管理器,在实例上右击---所有任务--附加数据库,然后选择那个.MDF文件,就可以了。

  或者在查询分析器中输入:

sp_attach_db "数据库名称","路径文件名.ldf","路径文件名.MDF"

  SQL Server数据库备份有两种方式,一种是使用BACKUP DATABASE将数据库文件备份出去,另外一种就是直接拷贝数据库文件mdf和日志文件ldf的方式。下面将主要讨论一下后者的备份与恢复。本文假定您能熟练使用SQL Server Enterprise Manager(SQL Server企业管理器)和SQL Server Quwey Analyser(SQL Server查询分析器)

  1、正常的备份、恢复方式

  正常方式下,我们要备份一个数据库,首先要先将该数据库从运行的数据服务器中断开,或者停掉整个数据库服务器,然后复制文件。

  卸下数据库的命令:Sp_detach_db 数据库名

  连接数据库的命令:Sp_attach_db或者sp_attach_single_file_db

s_attach_db [@dbname =] 'dbname', [@filename1 =] 'filename_n' [,...16]

sp_attach_single_file_db [@dbname =] 'dbname', [@physname =] 'physical_name'

  使用此方法可以正确恢复SQL Sever7.0和SQL Server 2000的数据库文件,要点是备份的时候一定要将mdf和ldf两个文件都备份下来,mdf文件是数据库数据文件,ldf是数据库日志文件。

  例子:

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/sqlserver/)

  假设数据库为test,其数据文件为test_data.mdf,日志文件为test_log.ldf。下面我们讨论一下如何备份、恢复该数据库。

  卸下数据库:sp_detach_db 'test'

  连接数据库:

sp_attach_db 'test','C:Program FilesMicrosoft SQL ServerMSSQLDatatest_data.mdf','C:Program FilesMicrosoft SQL ServerMSSQLDatatest_log.ldf'
sp_attach_single_file_db 'test','C:Program FilesMicrosoft SQL ServerMSSQLDatatest_data.mdf'

  2、只有mdf文件的恢复技术

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/sqlserver/)

  由于种种原因,我们如果当时仅仅备份了mdf文件,那么恢复起来就是一件很麻烦的事情了。

  如果您的mdf文件是当前数据库产生的,那么很侥幸,也许你使用sp_attach_db或者sp_attach_single_file_db可以恢复数据库,但是会出现类似下面的提示信息

  设备激活错误。物理文件名 'C:Program FilesMicrosoft SQL ServerMSSQLdatatest_Log.LDF' 可能有误。

  已创建名为 'C:Program FilesMicrosoft SQL ServerMSSQLDatatest_log.LDF' 的新日志文件。

来源:http://www.tulaoshi.com/n/20160129/1496552.html

延伸阅读
标签: SQLServer
SQL Server2000中,如果数据库文件(非系统数据库文件)遇到错误的时候,我们该怎么办。以下是笔者以前的笔记。仅适用于非master,msdb的数据库。   说明如下: 1 建一个测试数据库test(数据库类型为完全) 2 建一个表,插入点记录   create table a(c1 varchar(2))   go   insert into a values('aa')   go   ...
标签: ASP
<HTML <HEAD <TITLE数据库操作</TITLE <meta http-equiv="Content-Type" content="text/html; charset=gb2312" </HEAD <BODY <form method="post" name=myform <%if action="restore" then%<INPUT TYPE="hidden" name="action" value="resto...
标签: SQLServer
如果主数据库发生故障,那么微软的SQL Server可能会怦然倒下。看看如何面对这种事件,了解如何用企业管理器和查询分析器修复主数据库。 作为一名微软SQL Server的管理员,您必须知道如何修复一个崩溃的主数据库。主数据库保存有您的登录信息,以及最重要的、指向您所有数据库的指针。如果没有主数据库,您就无法成功地启动SQL Server。在本文...
在查询中执行下列语句 EXEC sp_attach_single_file_db @dbname = 'tggov_Data', @physname = 'E:tggov_Datawww.tulaoshi.com.MDF' 'tggov_Data' 为恢复的数据库名 'E:tggov_Datatggov_Data.MDF' 物理文件位置
SQL Server Compact是一种In-Process数据库引擎,它由多个DLL文件构成,下面就以SQL Server Compact 3.5为例子简单介绍一下每个DLL文件的作用。 sqlceca35.dll SQL Server Compact的客户端代理,客户端代理与服务端代理进行通信,实现RDA和Merge Replication数据同步。 sqlcecompact35.dll SQL Server Compact数据库修...

经验教程

464

收藏

56
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部