开发者社区> springfe> 正文

Sql数据库MDF数据文件数据库恢复

简介: EXEC sp_attach_db @dbname = 'dbname', @filename1 = 'd:\dbname_Data.MDF', @filename2 = 'd:\dbname_log.ldf'  sp_attach_single_file_db @dbname = 'dbname'  , @physname = 'physical_name'  dbname:即要还原的数据库名字。
+关注继续查看
EXEC sp_attach_db @dbname = 'dbname',
@filename1 = 'd:\dbname_Data.MDF',
@filename2 = 'd:\dbname_log.ldf' 


sp_attach_single_file_db @dbname = 'dbname'
  , @physname = 'physical_name'
  dbname:即要还原的数据库名字。
  Physname:即物理文件名。
  Physical_name:即.mdf文件路径。


数据库 : mssql server 2000 企业版
问题描述: 数据库置疑。数据库备份文件损坏。将数据库物理文件(*.mdf)拷贝出来 ,使用数据库附加功能,附加失败。
提示错误:
服务器: 消息 1813,级别 16,状态 2,行 1
未能打开新数据库 test。create database 将终止。
设备激活错误。物理文件名 d:test_log.ldf 可能有误。
进查找相关资料 解决方案如下:
a.我们使用默认方式建立一个供恢复使用的数据库(如test)。可以在sql server enterprise manager里面建立。
b.停掉数据库服务器。
c.将刚才生成的数据库的日志文件test_log.ldf删除,用要恢复的数据库mdf文件覆盖刚才生成的数据库数据文件test_data.mdf。
d.启动数据库服务器。此时会看到数据库test的状态为“置疑”。这时候不能对此数据库进行任何操作。
e.设置数据库允许直接操作系统表。此操作可以在sql server enterprise manager里面选择数据库服务器,按右键,选择“属性”,在“服务器设置”页面中将“允许对系统目录直接修改”一项选中。也可以使用如下语句来实现。
use master
go
sp_configure allow updates,1
go
reconfigure with override
go
f.设置test为紧急修复模式
update sysdatabases set status=-32768 where dbid=db_id(test)
此时可以在sql server enterprise manager里面看到该数据库处于“只读置疑脱机紧急模式”可以看到数据库里面的表,但是仅仅有系统表
g.下面执行真正的恢复操作,重建数据库日志文件
dbcc rebuild_log(test,c:program filesmicrosoft sql servermssqldatatest_log.ldf)
执行过程中,如果遇到下列提示信息:
服务器: 消息 5030,级别 16,状态 1,行 1
未能排它地锁定数据库以执行该操作。
dbcc 执行完毕。如果 dbcc 输出了错误信息,请与系统管理员联系。
说明您的其他程序正在使用该数据库,如果刚才您在f步骤中使用sql server enterprise manager打开了test库的系统表,那么退出sql server enterprise manager就可以了。
正确执行完成的提示应该类似于:
警告: 数据库 test 的日志已重建。已失去事务的一致性。应运行 dbcc checkdb 以验证物理一致性。将必须重置数据库选项,并且可能需要删除多余的日志文件。
dbcc 执行完毕。如果 dbcc 输出了错误信息,请与系统管理员联系。
此时打开在sql server enterprise manager里面会看到数据库的状态为“只供dbo使用”。此时可以访问数据库里面的用户表了。
h.验证数据库一致性(可省略)
dbcc checkdb(test)
一般执行结果如下:
checkdb 发现了 0 个分配错误和 0 个一致性错误(在数据库 test 中)。
dbcc 执行完毕。如果 dbcc 输出了错误信息,请与系统管理员联系。
i.设置数据库为正常状态
sp_dboption test,dbo use only,false
如果没有出错,那么恭喜,现在就可以正常的使用恢复后的数据库啦。
j.最后一步,我们要将步骤e中设置的“允许对系统目录直接修改”一项恢复。因为平时直接操作系统表是一件比较危险的事情。当然,我们可以在sql server enterprise manager里面恢复,也可以使用如下语句完成
sp_configure allow updates,0
go
reconfigure with override
go

 

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
SQL数据库学习之路(四)
要求:通过SQL语句创建以下基本表:    教师关系 T(T#, TNAME,TITLE)    课程关系 C(C#,CNAME,T#)    学生关系 S(S#,SNAME,AGE,SEX)    选课关系SC(S#,C#,SCORE)    班级关系CLASS(CLASSID,CLASSNAME)    其中红色粗体为主键,带下划线的属性为外键。
773 0
SQL数据库学习之路(七)
在SQL server managerment中可以点击帮助,会有帮助文档。 一、联合查询 将多个查询结果集合并成一个。
772 0
C# 以MDF文件连接数据库
由于没有安装 SQL Server 数据库服务,所以想着以MDF文件连接数据库(那么庞大的一个软件,安装之后想卸载?根本卸载不干静),是不是就可以不需要安装 SQL Server  了,可惜没有如愿以偿,必须要有  SQL Server 数据库服务,才能以MDF文件的形式连接数据库! 如果你仅仅是想查看 MDF文件 的内容,可以参考:MDF文件查看器(SQL MDF Viewer) 1.
891 0
SQL数据库学习之路(一)
1.数据库简介(一个放数据的仓库)  解决的问题:持久化存储,优化读写,保证数据的有效性 关系型数据库:    基于E-R模型(实体-联系图Entity Relationship)    使用sq|语言进行操作(SQL...
963 0
MYSQL数据库的参数文件
参数文件:告诉MySQL实例启动时在哪里可以找到数据库文件,并且指定某些初始化参数,这些参数定义了某种内存结构的大小等设置,还会介绍各种参数的类型。 参数文件 当MySQL实例启动时,MySQL会先去读一个配置参数文件,用来寻找数据库的各种文件所在位置以及指定某些初始化参数,这些参数通常定义了某种内存结构有多大等设置。
758 0
+关注
springfe
曾就职于欧洲跨国企业、国内知名互联网公司、国内NADAQ上市企业,从事互联网研发和技术团队管理工作,相继担任过高级开发工程师、高级经理、架构师、研发总监、CTO等职务。对于系统架构设计、算法设计、自动化运维和技术管理有较高的实战经验。
173
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
OceanBase 入门到实战教程
立即下载
阿里云图数据库GDB,加速开启“图智”未来.ppt
立即下载
实时数仓Hologres技术实战一本通2.0版(下)
立即下载