详细讲解SQL Server数据库的文件恢复技术

作者:20933 时间:2009-01-15 12:54:00 

SQL Server有两种备份方式,一种是使用BACKUP DATABASE将数据库文件备份出去,另外一种就是直接拷贝数据库文件mdf和日志文件ldf的方式。本文中我们将主要介绍一下后者的备份与恢复。本文中假定您目前已经能够熟练使用Server企业管理器和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是数据库日志文件。

例子:

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

卸下数据库:sp_detach_db ’test’

连接数据库:

sp_attach_db ’test’,’C:\Program Files\Microsoft SQL

Server\MSSQL\Data\test_data.mdf’,’C:\Program Files\Microsoft SQL

 Server\MSSQL\Data\test_log.ldf’

sp_attach_single_file_db ’test’,’C:\Program Files\Microsoft SQL

Server\MSSQL\Data\test_data.mdf’
 
2、只有mdf文件的恢复技术

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

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

设备激活错误。物理文件名 ’C:\Program Files\Microsoft SQL Server\MSSQL\data\test_Log.LDF’ 可能有误。

已创建名为 ’C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_log.LDF’ 的新日志文件。

但是,如果您的数据库文件是从其他计算机上复制过来的,那么很不幸,也许上述办法就行不通了。你也许会得到类似下面的错误信息

服务器: 消息 1813,级别 16,状态 2,行 1

未能打开新数据库 ’test’。CREATE DATABASE 将终止。

设备激活错误。物理文件名 ’d:\test_log.LDF’ 可能有误。

应该怎么办呢?下面我们举例说明恢复办法。

标签:
0
投稿

猜你喜欢

  • MySQL Create Database 创建数据库

    2011-09-10 16:04:51
  • MySQL常用维护管理工具

    2009-03-08 16:51:00
  • Dreamweaver MX技巧之超链接

    2009-05-29 18:40:00
  • asp如何显示已在数据库编码了的相对应的记录?

    2010-06-09 18:44:00
  • asp用正则解析远程图片地址,用XMLHTTP将其保存

    2007-10-26 12:34:00
  • 网页表单项Input的高级限制级用法

    2008-10-27 16:50:00
  • SQL进行排序、分组、统计的10个新技巧

    2009-01-23 13:59:00
  • class和id命名探讨

    2007-10-16 17:55:00
  • Web开发者的百科全书——Google DocType

    2008-07-03 13:06:00
  • 打分进化史

    2009-12-24 12:20:00
  • 网页的栅格设计思考

    2007-11-09 10:33:00
  • asp Driver和Provider两种连接字符串连接Access时的区别

    2011-03-09 11:19:00
  • 使用 XML 模板 (MSSQL手册)

    2008-09-04 14:25:00
  • ASP 调用带参数输出的COM接口

    2011-03-17 10:59:00
  • 当设计师遭遇HTML5

    2011-08-05 18:59:53
  • asp 随机字符串函数

    2011-04-04 11:01:00
  • 配置SQL Server 2000选项

    2010-04-25 11:01:00
  • 两行代码实现的QQ窗口抖动效果

    2008-09-06 12:34:00
  • 用css和js实现firefox和IE支持局部打印

    2008-05-23 13:04:00
  • Oracle数据库编写有效事务指导方针

    2009-03-19 17:41:00
  • asp之家 网络编程 m.aspxhome.com