找回密码
 注册账号

QQ登录

只需一步,快速开始

手机号码,快捷登录

手机号码,快捷登录

初学者课程:T3自学|T6自学|U8自学软件下载课件下载工具下载资料:通资料|U8资料|NC|培训|年结积分规则 | 使用常见问题Q&A
知识库:U8 | | NC | U9 | OA | 政务U8|U9|NCC|NC65|NC65客开|NCC客开新手必读 | 任务 | 快速增金币用友QQ群[微信群]
查看: 5168|回复: 7

[政务] 利用SQL数据库日志恢复数据到时间点的操作

[复制链接]
发表于 2009-8-4 18:41:02 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册账号

×
如果在使用update或delete语句忘带了where子句,或where子句精度不够,执行之后造成了严重的后果,这种情况的数据恢复只能利用事务日志的备份来进行,所以如果你的SQL没有进行相应的全库备份或不能备份日志(truncate  log  on  checkpoint选项为1),那么就无法进行数据的恢复了,或者只能恢复到最近一次的备份的数据了。
以下简单说明恢复数据方法:
1,如果误操作之前存在一个全库备份(或已有多个差异备份或增量备份),首先要做的事就是进进行一次日志备份(如果为了不让日志文件变大而置trunc.  log  on  chkpt.选项为1那你就死翘了)
       backup  log  dbName  to  disk='fileName'
2,恢复一个全库备份,注意需要使用with  norecovery,如果还有其他差异或增量备份,则逐个恢复
       restore  database  dbName  from  disk='fileName'  with  norecovery
3,恢复最后一个日志备份即刚做的日志备份,指定恢复时间点到误操作之前的时刻
       restore  log  dbName  from  disk='fileName'
       with  stopat='date_time'
以上这些操作都可以在SQL  SERVER企业管理器里完成,难度不大。。。
当然,如果误操作是一些不记日志的操作比如truncate  table,select  into等操作,那么是无法利用上述方法来恢复数据的。

评分

参与人数 1威望 +10 金币 +10 魅力 +10 收起 理由
jh4617233 + 10 + 10 + 10 谢谢分享!

查看全部评分

发表于 2009-8-6 10:45:25 | 显示全部楼层
还是Oracle好,可以回滚的
发表于 2009-8-20 19:39:24 | 显示全部楼层
看不太懂,不知在企业管理器里怎么操作
发表于 2009-8-21 16:18:06 | 显示全部楼层
oracle强大但没sql server 易用
发表于 2009-8-25 17:12:42 | 显示全部楼层
发表于 2009-9-3 11:23:22 | 显示全部楼层
如果覆盖还原了,还能用这种方法吗
发表于 2010-12-10 16:27:14 | 显示全部楼层
收藏,学习
发表于 2011-5-25 17:55:12 | 显示全部楼层
顶起···
您需要登录后才可以回帖 登录 | 注册账号

本版积分规则

QQ|站长微信|Archiver|手机版|小黑屋|用友之家 ( 蜀ICP备07505338号|51072502110008 )

GMT+8, 2024-11-23 09:26 , Processed in 0.042567 second(s), 8 queries , Gzip On, Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表