详细讲解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
投稿

猜你喜欢

  • 理解 javascript 中的函数表达式与函数声明

    2024-04-23 09:08:26
  • Linux下修改MySQL数据库数据文件路径的步骤

    2024-01-19 13:53:41
  • Python 200行代码实现一个滑动验证码过程详解

    2022-08-24 18:24:35
  • 如何通过PHP实现Des加密算法代码实例

    2023-10-08 09:41:55
  • python wsgiref源码解析

    2023-10-20 10:56:27
  • SQL窗口函数之排名窗口函数的使用

    2024-01-26 18:49:31
  • Mysql中的concat函数(拼接函数)详解

    2024-01-27 21:01:37
  • Python实现多线程下载文件的代码实例

    2022-11-06 02:41:12
  • MySQL触发器简单用法示例

    2024-01-26 11:26:53
  • asp.net 为FCKeditor开发代码高亮插件实现代码

    2023-09-26 00:30:16
  • PyQt5+pycharm开发环境搭建的实现步骤(图文)

    2021-05-19 17:27:40
  • C#访问PostGreSQL数据库的方法

    2024-01-23 01:00:13
  • 在Python运行时动态查看进程内部信息的方法

    2021-06-09 09:15:40
  • Jinja2过滤器的使用、控制语句示例详解

    2023-01-30 19:02:00
  • python实现统计代码行数的方法

    2021-06-23 11:24:17
  • 简单了解python关键字global nonlocal区别

    2023-07-26 15:47:07
  • Python logging模块原理解析及应用

    2022-04-08 11:14:32
  • Python 日志管理模块Loguru的用法小结

    2023-02-22 15:45:16
  • Python代码实现列表分组计数

    2022-11-03 07:58:38
  • 七种PHP开发环境搭建工具

    2023-10-25 13:47:48
  • asp之家 网络编程 m.aspxhome.com