失而复得——数据库日志文件丢失后的恢复
上一篇 /
下一篇 2012-08-22 09:28:02
/ 个人分类:数据库
51Testing软件测试网.i.{$z5V"g{)k:AIe~ 前几天听英语用到虚拟光驱装resseta stone,没想到各种不顺,把我的本本给整瘫痪了。后来重整旗鼓,装了云端,总算是把它搞定了,由于瘫痪来的很突然,所以我的一些数据不小心丢了一些。我新建的数据库日志文件就悲催的丢啦。其实新建一个数据库完全可以,只是觉得现在碰到了,而且也不是没有时间,可以查找一下解决方案,以备以后自己和他人遇到一些类似的情况不必再犯难。51Testing软件测试网x:|]4og(w%T{
x+^7^HTS-[U2~0 下面来说一下恢复方法:
u6Q%O(d
?0@FWJg$fx0 如果你的数据还在数据库服务器中,请执行以下三步
2{,MD0U/UI k051Testing软件测试网h8j?,B%~ 1、停止数据库服务。
]Q$}fmR;i F0&z8ED7Mj'_k'|-wG0[0 2、将需要恢复的数据库文件复制到另外的位置,然后在SQLServerManagement Studio中删除要恢复的数据库。51Testing软件测试网|e)L-mZ
xh
51Testing软件测试网'zFn,U
}\i6ap 3、启动数据库服务。
c3nZv2]2F9SWk0(bQ
Q#i!]#f0 接下来51Testing软件测试网PmyT4q|
51Testing软件测试网;h [G4m#a U 1、新建同名的数据库(数据库文件名也要相同)。
+v"~,p'?`0,OB5`U7__/Id
ht0 2、停止数据库服务。51Testing软件测试网F7j7`/Bx_+q Ot4q
I^NTa#a0 3、用备份的.mdf文件覆盖新数据库的同名文件。
g] ?W9Z051Testing软件测试网Z;PPb)rT 4、启动数据库服务。
K9t*@,m(}$s{O01M/C9\ Ib
qI5|1^&R0 5、在查询分析器中:运行如下代码将数据库设置为紧急状态
4v:GJi2g.xHR$JZ0alter database dbname set emergency |
,yl4\W/~m#z,R0 例如恢复的数据库名为:MRcharge,图如下
ylNWOZ8|c051Testing软件测试网A1yw1N`tZ*^.Q
6、然后再查询中输入如下语句就可以恢复数据库了:
|-g/_)GY0mvFX$\:pX:^0use master 51Testing软件测试网xp0[4qn+d\,xQ 51Testing软件测试网$K2VL!V RwHdeclare @databasename varchar(255) 51Testing软件测试网0D
L@wrbxQ8|-]'\ 51Testing软件测试网I I j^'?xO8E2c\|set @databasename='MRcharge' 0c_0_WO06@W z(W!M/{^~c8A8Tk0exec sp_dboption @databasename, N'single', N'true'
--将恢复数据库置为单用户状态 51Testing软件测试网
xL6]9uP;~ 51Testing软件测试网:x
j}-t[5zudbcc checkdb('MRcharge',REPAIR_ALLOW_DATA_LOSS) H0gz d?i2A+U6R051Testing软件测试网%e];^!W WMdbcc checkdb('MRcharge',REPAIR_REBUILD) 2b}Y,F m X051Testing软件测试网sKO"B&d,Sf e's"Cexec sp_dboption 'MRcharge', N'single', N'false' --最后再将恢复数据库置为多用户状态 %J'i7Q,k6le+TJ7og0 |
注意:这种方法恢复必须保证你建立数据库和恢复数据库用的是统一版本,即:都是sql server 2000,或者 2005,或者2008。
l/F6xb8W8dN6W8D0 我曾想用sql server 2008恢复2005的数据库,结果提示版本过低,无法打开,需要升级,于是我在建数据库的时候特意把兼容级别改成2005的,结果还是一样。
4xc9Y
g7M]"^Bi6s0 跨版本恢复待求解,请指点。51Testing软件测试网t,@t\lI{
收藏
举报
TAG: