Heim > Datenbank > MySQL-Tutorial > 失而复得数据库日志文件丢失后的恢复

失而复得数据库日志文件丢失后的恢复

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Freigeben: 2016-06-07 15:12:04
Original
1182 Leute haben es durchsucht

前几天听英语用到虚拟光驱装resseta stone ,没想到各种不顺,把我的本本给整瘫痪了。后来重整旗鼓,装了云端,总算是把它搞定了,由于瘫痪来的很突然,所以我的一些数据不小心丢了一些。我新建的数据库日志文件就悲催的丢啦。其实新建一个数据库完全可以,只

前几天听英语用到虚拟光驱装resseta stone ,没想到各种不顺,把我的本本给整瘫痪了。后来重整旗鼓,装了云端,总算是把它搞定了,由于瘫痪来的很突然,所以我的一些数据不小心丢了一些。我新建的数据库日志文件就悲催的丢啦。其实新建一个数据库完全可以,只是觉得现在碰到了,而且也不是没有时间,可以查找一下解决方案,以备以后自己和他人遇到一些类似的情况不必再犯难。


下面来说一下恢复方法

如果你的数据还在数据库服务器中,请执行,一下三步

1、停止数据库服务。

2、将需要恢复的数据库文件复制到另外的位置,然后在SQL Server Management Studio中删除要恢复的数据库。

3、启动数据库服务。

接下来

1、新建同名的数据库(数据库文件名也要相同)

2、停止数据库服务。

3、用备份的.mdf文件覆盖新数据库的同名文件。

4、启动数据库服务。

5、在查询分析器中:运行如下代码将数据库设置为紧急状态

alter database dbname set emergency 
Nach dem Login kopieren


 

例如恢复的数据库名为:MRcharge,图如下


失而复得数据库日志文件丢失后的恢复


6、然后再查询中输入如下语句就可以恢复数据库了:

 

use master 

declare @databasename varchar(255) 

set @databasename='MRcharge' 

exec sp_dboption @databasename, N'single', N'true'               --将恢复数据库置为单用户状态 

dbcc checkdb('MRcharge',REPAIR_ALLOW_DATA_LOSS) 

dbcc checkdb('MRcharge',REPAIR_REBUILD) 

exec sp_dboption 'MRcharge', N'single', N'false'              --最后再将恢复数据库置为多用户状态 
Nach dem Login kopieren



 

 

注意:这种方法恢复必须保证你建立数据库和恢复数据库用的是统一版本,即:都是sql server 2000,或者 2005 ,或者2008

我曾想用sql server 2008恢复2005的数据库,结果提示版本过低,无法打开,需要升级,

于是我在建数据库的时候特意把兼容级别改成2005的,结果还是一样。

跨版本恢复待求解,请指点。

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage