日志文件丢失或出错的情况下如何恢复SQL数据库

日志文件丢失或出错的情况下如何恢复SQL数据库,第1张

1. 新建数据库(同名)

2. 停掉数据库

3. 删除新建数据库的日志文件,用要恢复的覆盖mdf文件

4. 启动数据库服务器

5. 设置数据库允许直接 *** 作系统表

6. 设置数据库为紧急修复模式

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

7. 重建数据库日志文件

dbcc rebuild_log('dbDataHome','D:\Data\dbData_Data.LDF')

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

dbcc checkdb('dbDataHome')

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

exec sp_dboption 'dbDataHome','dbo use only','false'

10. 最后一步,我们要将步骤E中设置的“允许对系统目录直接修改”一项恢复。

使用Log Explorer查看和恢复数据

Log Explorer 4.1.可用于SQL Server2005的日志查看工具

下载地址:

http://download.csdn.net/source/620271

使用方法:

打开Log Explorer ->Attach Log File ->选择SQL Server服务器和登陆方式 ->Connect ->

在Database Name中选择数据库 ->Attach->左面对话框中Browse->View Log->就可以看到log记录了

想恢复的话: 右键Log记录 Undo Transation->选择保存文件名和路径->然后打开该文件到查询分析器里执行

T-sql代码就可以了

例如 如果Log是delete table where ...的话,生成的文件代码就是insert table ....

然后将此insert table的代码放到查询分析器里执行.就可以恢复数据.

----------------------------------------------------------------------

--如何恢复被delete/update的数据

----------------------------------------------------------------------

1 连接到被删除数据库的Db

打开log explorer 选择 "file"->"attach log file"->选择服务器和登陆方式->"connect"->选择"数据库"->"attach"

2 查看日志

在左面 *** 作项目的对话框中选择"browse"项目->"view log"->就可以看到当前的Log记录了

3 恢复数据

右键某一条log记录,选择"undo transation"->"选择保存文件名和路径"->然后打开该文件到查询分析器里执行

T-sql代码就可以了

例如: 如果log是delete table where ...的话,生成的文件代码就是insert table ....

----------------------------------------------------------------------

--Log Explorer恢复被drop table和truncate table后的数据

----------------------------------------------------------------------

1 连接到被删除数据库的Db

*** 作同上

2 恢复方法

1) 选择"salvaage dropped/truncate"菜单,在右边的对话框中选择表名,和droped/trucated的日期,

File Name中选择生成insert语句脚步的存放位置,condition选择是droped还是truncated,

最后点击"create" 就会生成insert语句,把生成的语句到查询分析器里面执行一下就可以了

2) 选择"ViewDDL Commands"菜单->选"truncate table" *** 作项->点击"Salvage"->生成语句->查询分析器里执行

----------------------------------------------------------------------

--log explorer使用的几个问题

----------------------------------------------------------------------

1) 对数据库做完全/差异/日志备份

备份时如果选用了删除事务日志中不活动的条目

再用Log explorer打试图看日志时,提示No log recorders found that match the filter,would you like to view unfiltered data 选择yes 就看不到刚才的记录了

如果不选用了删除事务日志中不活动的条目

再用Log explorer打试图看日志时,就能看到原来的日志并做恢复

2) 修改了其中一个表中的部分数据,此时用Log explorer看日志,可以作日志恢复

3) 然后恢复备份,(注意:恢复是断开log explorer与数据库的连接,或连接到其他数据上,

否则会出现数据库正在使用无法恢复)

恢复完后,再打开log explorer 提示No log recorders found that match the filter,would you like to view unfiltered data,选择yes 就看不到刚才在2中修改的日志记录,所以无法做恢复.

4) 不要用SQL的备份功能备份,搞不好你的日志就破坏了.

正确的备份方法是:

停止SQL服务,复制数据文件及日志文件进行文件备份.

然后启动SQL服务,用log explorer恢复数据

从日志回复数据库

:自己一步一步按照说明试着看

--创建测试数据库

create

database

db

go

--对数据库进行备份

backup

database

db

to

disk='c:\db.bak'

with

format

go

--创建测试表

create

table

db.dbo.tb_test(id

int)

--延时1秒钟,再进行后面的 *** 作(这是由于sql

server的时间精度最大为百分之三秒,不延时的话,可能会导致还原到时间点的 *** 作失败)

waitfor

delay

'00:00:01'

go

--假设我们现在误 *** 作删除了

db.dbo.tb_test

这个表

drop

table

db.dbo.tb_test

--保存删除表的时间

select

dt=getdate()

into

#

go

--在删除 *** 作后,发现不应该删除表

db.dbo.tb_test

--下面演示了如何恢复这个误删除的表

db.dbo.tb_test

--首先,备份事务日志(使用事务日志才能还原到指定的时间点)

backup

log

db

to

disk='c:\db_log.bak'

with

format

go

--接下来,我们要先还原完全备份(还原日志必须在还原完全备份的基础上进行)

restore

database

db

from

disk='c:\db.bak'

with

replace,norecovery

go

--将事务日志还原到删除 *** 作前(这里的时间对应上面的删除时间,并比删除时间略早

declare

@dt

datetime

select

@dt=dateadd(ms,-20,dt)

from

#

--获取比表被删除的时间略早的时间

restore

log

db

from

disk='c:\db_log.bak'

with

recovery,stopat=@dt

go

--查询一下,看表是否恢复

select

*

from

db.dbo.tb_test

/*--结果:

id

-----------

(所影响的行数为

0

行)

--*/

--测试成功

go

--最后删除我们做的测试环境

drop

database

db

drop

table

#


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

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

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

发表评论

登录后才能评论

评论列表(0条)

    保存