数据库被删除怎么恢复

数据库被删除怎么恢复,第1张

sql

server中误删除数据的恢复本来不是件难事,从事务日志恢复即可。但是,这个恢复需要有两个前提条件:

1.

至少有一个误删除之前的数据库完全备份

2.

数据库的恢复模式(recovery

mode)是“完整(full)”。

针对这两个前提条件,会有三种情况:

情况一、如果这两个前提条件都存在,通过sql语句只需三步就能恢复(参考文章),无需借助第三方工具。

a)

备份当前数据库的事务日志:backup

log

[数据库名]

to

disk=

n'备份文件名'

with

norecovery

b)

恢复一个误删除之前的完全备份:restore

database

[数据库名]

from

disk

=

n'完全备份文件名'

with

norecovery,

replace

c)

将数据库恢复至误删除之前的时间点:restore

log

[数据库]

from

disk

=

n'第一步的日志备份文件名'

with

stopat

=

n'误删除之前的时间点'

,

recovery

情况二、如果第1个前提条件不存在,第2个前提条件存在,需要借助第三方工具。

情况三、如果第2个前提条件不存在,无法恢复。所以,一定要将数据库恢复模式设置为“完整(full)”。

我现在面临的是第二种情况,需要找第三方工具。

开始找的是log

explorer

for

sql

server,不支持sql

server

2008。

后来找的是sql

log

rescue,也不支持sql

server

2008。

接着找到的是systools

sql

recovery,支持sql

server

2008,但需要购买,demo版并没有数据恢复功能。

最终在officerecovery.com上找到recovery

for

sql

server,虽然也是商业软件,需要购买,但demo版可以恢复数据,只要数据库文件不超过24gb。幸好朋友的数据库文件不大,用它完成了误删除数据的恢复。

下面分享一下用recovery

for

sql

server进行恢复的 *** 作步骤:

1.

运行recovery

for

sql

server

2.

点击菜单中的

file

>

recover,选择要恢复的数据库的数据文件(.mdf)

3.

next

>

next,进入

recovery

configuration

界面,选择custom(选择了custom才可以选择从日志中恢复误删除的数据)。

4.

next

进入

recovery

options

窗口,选中

search

for

deleted

records,并选择要恢复的数据库的日志文件路径(log

file

path)。

5.

next

并选择目标文件夹(destination

folder),用于存放恢复过程中生成的sql语句与bat文件。

6.

点击start,开始恢复 *** 作(在上一步选择的目标文件夹中生成相应的sql文件与bat文件),然后,出现

sql

server

database

creation

utility

窗口。

7.

next,选择被恢复数据存放的目标数据库。

8.

next,

选择

import

availiable

data

from

both

database

and

log

files

9.

next,

next,

然后就完成数据的恢复!

按照正常的数据库备份 *** 作备份一下数据库,然后按照后面的 *** 作只还原数据文件 A. 我们使用默认方式建立一个供恢复使用的数据库(如test)。可以在SQL Server Enterprise Manager里面建立。

B. 停掉数据库服务器。

C. 将刚才生成的数据库的日志文件test_log.ldf删除,用要恢复的数据库mdf文件覆盖刚才生成的数据库数据文件test_data.mdf。

D. 启动数据库服务器。此时会看到数据库test的状态为“置疑”。这时候不能对此数据库进行任何 *** 作。

E. 设置数据库允许直接 *** 作系统表。此 *** 作可以在SQL Server Enterprise Manager里面选择数据库服务器,按右键,选择“属性”,在“服务器设置”页面中将“允许对系统目录直接修改”一项选中。也可以使用如下语句来实现。

use master

go

sp_configure 'allow updates ',1

go

reconfigure with override

go

F. 设置test为紧急修复模式

update sysdatabases set status=-32768 where dbid=DB_ID( 'text ')

此时可以在SQL Server Enterprise Manager里面看到该数据库处于“只读\置疑\脱机\紧急模式”可以看到数据库里面的表,但是仅仅有系统表

G. 下面执行真正的恢复 *** 作,重建数据库日志文件

dbcc rebuild_log( 'text ', 'D:\MSSQL7\Data\text_log.ldf ')

执行过程中,如果遇到下列提示信息:

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

未能排它地锁定数据库以执行该 *** 作。

DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

说明您的其他程序正在使用该数据库,如果刚才您在F步骤中使用SQL Server Enterprise Manager打开了text库的系统表,那么退出SQL Server Enterprise Manager就可以了。

正确执行完成的提示应该类似于:

警告: 数据库 'test ' 的日志已重建。已失去事务的一致性。应运行 DBCC CHECKDB 以验证物理一致性。将必须重置数据库选项,并且可能需要删除多余的日志文件。

DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

此时打开在SQL Server Enterprise Manager里面会看到数据库的状态为“只供DBO使用”。此时可以访问数据库里面的用户表了。

H. 验证数据库一致性(可省略)

dbcc checkdb( 'text ')

一般执行结果如下:

CHECKDB 发现了 0 个分配错误和 0 个一致性错误(在数据库 'test ' 中)。

DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

I. 设置数据库为正常状态

sp_dboption 'text ', 'dbo use only ', 'false '

如果没有出错,那么恭喜,现在就可以正常的使用恢复后的数据库啦。

J. 最后一步,我们要将步骤E中设置的“允许对系统目录直接修改”一项恢复。因为平时直接 *** 作系统表是一件比较危险的事情。当然,我们可以在SQL Server Enterprise Manager里面恢复,也可以使用如下语句完成

sp_configure 'allow updates ',0

go

reconfigure with override

go


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/6701178.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-03-27
下一篇2023-03-27

发表评论

登录后才能评论

评论列表(0条)

    保存