数据库数据被批量修改,SQL自动生成的备份无法使用,想通过LDF文件或LOG进行恢复数据,不知道是否可行?若可行,该如何操作?

解决方案 »

  1.   

    用日志工具Log   Explorer  
    步骤:  
    1、查看日志  
          a、打开log   explorer,选择菜单File--> attach   log   file        
          b、在Log   File   Selection窗口中,填写连接到要恢复数据的数据库服务器机器名、数据库登录ID及密码,然后点击"Connect"按钮。  
          c、若连接成功,则窗口左边树将显示命令菜单,这时我们点击Browser下的View   Log命令,此时窗口右边则出现该数据库的Log。  
    2、恢复数据库  
          这时您只要选择您要恢复对事件点,右键点击选择"undo   transation"命令,保存T-SQL代码,然后在查询分析器中执行该T-SQL代码 
      

  2.   

    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   '