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

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介:
+关注继续查看

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

  下面来说一下恢复方法:

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

  1、停止数据库服务。

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

  3、启动数据库服务。

  接下来

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

  2、停止数据库服务。

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

  4、启动数据库服务。

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

alter database dbname set emergency

  例如恢复的数据库名为: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'              --最后再将恢复数据库置为多用户状态 

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

  我曾想用sql server 2008恢复2005的数据库,结果提示版本过低,无法打开,需要升级,于是我在建数据库的时候特意把兼容级别改成2005的,结果还是一样。

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








====================================分割线================================



最新内容请见作者的GitHub页:http://qaseven.github.io/

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
25天前
|
存储 SQL 关系型数据库
数据库的备份与恢复
数据库的备份与恢复
39 0
|
12月前
|
存储 SQL 安全
Mysql数据库的备份与恢复
Mysql数据库的备份与恢复
105 0
Mysql数据库的备份与恢复
|
关系型数据库 MySQL 数据库
MySQL数据库的备份与恢复(下)
一、数据备份的重要性 备份的主要目的是灾难恢复。 在生产环境中,数据的安全性至关重要。 任何数据的丢失都可能产生严重的后果。
123 0
|
安全 关系型数据库 MySQL
MySQL数据库的备份与恢复(中)
一、数据备份的重要性 备份的主要目的是灾难恢复。 在生产环境中,数据的安全性至关重要。 任何数据的丢失都可能产生严重的后果。
175 0
|
SQL Web App开发 关系型数据库
|
SQL 数据库 关系型数据库
|
关系型数据库 MySQL 数据库
|
Oracle 关系型数据库 数据库
|
Oracle 关系型数据库 数据库
推荐文章
更多