首页 新闻 论坛 群组 Blog 文档 下载 读书 Tag 网摘 搜索 .NET Java 游戏 视频 人才 外包 培训 数据库 书店 程序员
中国软件网
欢迎您:游客 | 登录 注册 帮助
  • 再次请教如何恢复被删的sql数据库记录 [已结贴,结贴人:kxlt2008]
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • kxlt2008
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    • 揭帖率:
    发表于:2008-05-09 23:25:37 楼主
    昨天发了一个如何恢复被删的sql数据库记录的帖子,马上有热心的高手帮忙指教,非常感谢。
    今天我马上把数据库文件拷贝到另一台计算机上,使用log explorer进行恢复,发觉可以恢复些被删的记录,但是原来那些被删的记录(标志‘有效’的)并没有恢复,认真的核对log记录,但是并没发现删除‘有效’标志的日志,不知道为什么?
    自己也尝试用delete命令删除sql数据库的部分记录,使用log explorer马上就可恢复,为什么却不能恢复前面说的那些标志‘有效’被删的记录,请高手再帮帮忙,谢谢。
    20  修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • gaojier1000
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    发表于:2008-05-10 08:25:551楼 得分:15
    log explorer是可以进行数据删除恢复的。可能是你的操作方式不正确吧。

    Log  Explorer 

    http://www.ttdown.com/SoftDown.asp?ID=14562 
    http://js.fixdown.com/soft/8324.htm 
    http://www.yiii.net/app/servlet/net.yiii.club.DownloadServlet?Information_Id=I00023471 
    解压缩密码  www.heibai.net 

    http://www.ttdown.com/softview_8647.htm 


    注册机产生的是注册码,是两个 

    用解压缩密码解开后,压缩包里也有一个注册机的 

    打开log  explorer  file=> attach  log  file-> 选择服务器和登陆方式-> connect-> 
    选择数据库-> attach-> 左面对话框中browse-> view  log-> 就可以看到log记录了 
    想恢复的话:  右键log记录  undo  transation-> 选择保存文件名和路径-> 然后打开该文件到查询分析器里执行 
    T-sql代码就可以了 

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


    Log  Explorer  for  SQL  Server  v3.3  特别版 
    www.chinaz.com 


    Log  Explorer  is  the  leading  transaction  analysis  and  data  recovery  solution  for  Microsoft  SQL  Server.  By  providing  unprecedented  access  to  the  SQL  Server  transaction  log,  Log  Explorer  gives  you  the  ability  to  understand  and  solve  elusive  database  problems  by  browsing  the  transaction  log,  exporting  data  to  create  reports,  and  selectively  recovering  modified,  deleted,  dropped,  or  truncated  data. 


    打开log  explorer  file=> attach  log  file-> 选择服务器和登陆方式-> connect-> 
    选择数据库-> attach-> 左面对话框中browse-> view  log-> 就可以看到log记录了 
    想恢复的话:  右键log记录  undo  transation-> 选择保存文件名和路径-> 然后打开该文件到查询分析器里执行 
    T-sql代码就可以。。。 

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

    右键log记录  undo  transation-> 选择保存文件名和路径-> 然后打开该文件到查询分析器里执行T-sql代码。。。 

    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中修改的日志记录,所以无法做恢复. 

    -------------------------------------------------------------------------------- 
    系统中有一个数据库DB1,系统正在使用的过程中,不小心删除了某表T1的数据 
    现我可以按照用完整备份文件加日志备份时间点TIME1恢复的方法来恢复该数据库 

    但问题出在该数据库一直还必须在使用中,所以除了你删除了数据的TA表外,其它的 
    表的数据你不能只是恢复到错误时间点TIME1处,因为,TIME1以后也有数据变化 

    解决这个问题有两个方法 
    1:用LOG  EXEPLORE  可以轻松搞定 

    2:先建立一个数据库DB2,将完整备份文件恢复到DB2中,再用DB2中的T1数据来更新 
          DB1中的T1数据即可. 


    --查看备份信息 
    RESTORE  FILELISTONLY  FROM  DISK  = 'C:\Program  Files\Microsoft  SQL  Server\MSSQL\BACKUP\db1_backup ' 

    --还原旧的备份   
    RESTORE  DATABASE  db2  FROM  DISK  =  'C:\Program  Files\Microsoft  SQL  Server\MSSQL\BACKUP\db1_backup '  with  replace,norecovery, 
    move  'db1_Data '  to  'C:\Program  Files\Microsoft  SQL  Server\MSSQL\data\db2_data.mdf ', 
      move  'db1_Log '  to  'C:\Program  Files\Microsoft  SQL  Server\MSSQL\data\db2_log.ldf '   

    --还原数据日志到时间点 
    restore  log    db2    from  disk= 'db_log_backup '    with  stopat= '2003/4/22  9:57 '
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • kxlt2008
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    发表于:2008-05-10 11:17:432楼 得分:0
    我是这样恢复的,打开log  explorer  file=> attach  log  file-> 选择服务器和登陆方式-> connect-> 
    选择数据库-> attach-> filter log records设定范围->Undo user Transcations选择保存文件名和路径->Run sql script运行T_sql代码恢复。
    但是这样没有恢复那些‘有效’标志的记录
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • dawugui
    • 等级:
    • 可用分等级:
    • 总技术专家分:
    • 总技术专家分排名:
    • 3

      3

    发表于:2008-05-10 11:25:043楼 得分:5
    逐一查询日志,看数据变化情况.
    修改 删除 举报 引用 回复

    网站简介广告服务网站地图帮助联系方式诚聘英才English 问题报告
    北京创新乐知广告有限公司 版权所有 京 ICP 证 070598 号
    世纪乐知(北京)网络技术有限公司 提供技术支持
    Copyright © 2000-2008, CSDN.NET, All Rights Reserved