首页 新闻 论坛 群组 Blog 文档 下载 读书 Tag 网摘 搜索 .NET Java 游戏 视频 人才 外包 培训 数据库 书店 程序员
中国软件网
欢迎您:游客 | 登录 注册 帮助
  • 数据误删,如何恢复(急) [已结贴,结贴人:blury]
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    发表于:2008-07-24 12:28:15 楼主
      我误删了表里的所有数据,数据表里有image图像数据。
      数据库以前没有备份,如何能恢复过来呢?
      望大家帮忙,急啊!
    50  修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    发表于:2008-07-24 12:31:131楼 得分:34
    使用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 '
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    发表于:2008-07-24 12:32:502楼 得分:8
    用log explorer試試看
    祝你好運~!~~
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    发表于:2008-07-24 12:33:273楼 得分:0
    数据库有没有日志,如果有的话可以,手工也行语句也行。
    --以上个人观点仅供参考
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • jinghao666666
    • 等级:
    发表于:2008-07-24 12:33:314楼 得分:0
    学习
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    发表于:2008-07-24 12:41:095楼 得分:8
    用log explorer試試看
    祝你好運~!~~
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    发表于:2008-07-24 12:45:516楼 得分:0
    看钻钻地.~
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    发表于:2008-07-24 14:04:187楼 得分:0
    高手哦,赶紧一块学习学习
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    发表于:2008-07-24 14:06:118楼 得分:0
    版主可以给我加钻钻吗?
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    发表于:2008-07-24 14:32:559楼 得分:0
     谢谢大家
      我以前已用过log explorer,但是好像image中的数据恢复不过来吧
      我试试吧
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    • lgxyz
    • 等级:
    发表于:2008-07-24 14:38:3310楼 得分:0
    Log Explorer
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    发表于:2008-07-24 17:30:3311楼 得分:0
    log explorer 连中文恢复有时候也会出现乱码  领教过的
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    发表于:2008-07-24 17:36:2512楼 得分:0
    试过了,也崩溃了。
    log explorer能实现大部分数据的恢复。
    但由于上午我用如下方法恢复过一次。
    backup database YSD_Data to disk='E:\YSD_Datatestdb.bak' 

    backup log YSD_Data to disk='E:\YSD_Datalog.dbf'

    restore database YSD_Data from disk='E:\YSD_Datatestdb.bak' with norecovery

    restore log YSD_Data from disk='E:\YSD_Datalog.dbf'  with recovery,stopat='2008-07-01 12:15:50'

    所以导致现在现在该数据库在Log Explorer里没有log记录,生不成对应的sql。
    还有挽救吗?
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    发表于:2008-07-24 17:45:4213楼 得分:0

      现在留下来的只有 以上操作中生成 的 'E:\YSD_Datalog.dbf'
      和在误删数据后,用sqlserver数据库备份功能备份的ysd_bak文件。
        还有救吗?
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    发表于:2008-07-24 20:09:3814楼 得分:0
      我在
      backup database YSD_Data to disk='E:\YSD_Datatestdb.bak' 
      的时候,日志文件就被截断了吗?
      这一操作以后Log Explorer里没有log记录了
      那'E:\YSD_Datatestdb.bak' 
        'E:\YSD_Datalog.dbf'
      还有什么用?
      郁闷!!!
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    发表于:2008-07-25 09:42:1015楼 得分:0
    向邹老大学习
    修改 删除 举报 引用 回复
    进入用户个人空间
    加为好友
    发送私信
    在线聊天
    发表于:2008-07-25 09:51:2716楼 得分:0

        现在邹老大的方法也挽救不了了
          我真是活傻瓜一个
    修改 删除 举报 引用 回复

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