日志文件是否是好的?
SQL数据库中的MDF文件不慎丢失怎么办?试试恢复小技巧。
http://topic.csdn.net/u/20080704/18/d999d98c-d1b4-4a14-bd93-61b200170a0d.html

解决方案 »

  1.   

    对应``MDF和LDF都是在恢复的SQL存档里拷出来的.但是没办法附加
      

  2.   

    或者使用下面的方法:Log Explorerhttp://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.nethttp://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'
      

  3.   

     先把要恢复的文件置于MS SQL里的DATA文件里,进入MS SQL主数据库服务器。   1.我们使用默认方式建立一个供恢复使用的数据库(如MHDYF2005)。可以在SQL Server里面建立。 
      2.停掉数据库服务器。 
      3.将刚才生成的数据库的日志文件MHDYF2005_log.ldf删除,用要恢复的数据库mdf(yu1.mdf)文件覆盖刚才生成的数据库数据文件MHDYF2005_data.mdf。 
      4.启动数据库服务器。(刷新之后)此时会看到数据库MHDYF2005的状态为“置疑”。这时候不要对此数据库进行任何操作。 
      5.设置数据库允许直接操作系统表。此操作可以在SQL Server Enterprise Manager里面选择数据库服务器,按右键,选择“属性”,在“服务器设置”页面中将“允许对系统目录直接修改”一项选中。也可以使用如下语句来实现。 
    SQL codeuse master
    go
    exec sp_configure 'allow updates',1
    go
    reconfigure with override
    go  6.设置MHDYF2005为紧急修复模式,语句如下: 
    SQL code   update sysdatabases set status=-32768 where dbid=DB_ID('MHDYF2005')按照此方法往下时,执行第七条SQL codedbcc rebuild_log
    ('MHDYF2005','C:\Program Files\Microsoft 
    SQL Server\MSSQL\Data\MHDYF2005_log.ldf')出现如下错语``
    服务器: 消息 5180,级别 22,状态 1,行 1
    由于文件 ID 35272(位于数据库 'shhesuan' 中)无效,所以未能打开 FCB。打开数据库已经被设为置疑,脱机,紧急模式.但里面什么表都没有```
      

  4.   

    MSSQL数据恢复工具MDFview.exe是一款专门从损坏的MDF文件直接提取表数据的程序。无须安装,直接使用。
    直接用SQL数据恢复工具MDFview.exe,该工具直接读取MDF文件,可以从损坏的MDF中提取数据
     下载地址http://www.minisoft.cn/mdfview.rar