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

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
日志服务 SLS,月写入数据量 50GB 1个月
简介: 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

 

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
3月前
|
存储 人工智能 Cloud Native
云栖重磅|从数据到智能:Data+AI驱动的云原生数据库
在9月20日2024云栖大会上,阿里云智能集团副总裁,数据库产品事业部负责人,ACM、CCF、IEEE会士(Fellow)李飞飞发表《从数据到智能:Data+AI驱动的云原生数据库》主题演讲。他表示,数据是生成式AI的核心资产,大模型时代的数据管理系统需具备多模处理和实时分析能力。阿里云瑶池将数据+AI全面融合,构建一站式多模数据管理平台,以数据驱动决策与创新,为用户提供像“搭积木”一样易用、好用、高可用的使用体验。
云栖重磅|从数据到智能:Data+AI驱动的云原生数据库
|
30天前
|
数据采集 数据库 Python
有哪些方法可以验证用户输入数据的格式是否符合数据库的要求?
有哪些方法可以验证用户输入数据的格式是否符合数据库的要求?
134 75
|
3月前
|
存储 监控 数据处理
flink 向doris 数据库写入数据时出现背压如何排查?
本文介绍了如何确定和解决Flink任务向Doris数据库写入数据时遇到的背压问题。首先通过Flink Web UI和性能指标监控识别背压,然后从Doris数据库性能、网络连接稳定性、Flink任务数据处理逻辑及资源配置等方面排查原因,并通过分析相关日志进一步定位问题。
272 61
|
2月前
|
SQL 存储 运维
从建模到运维:联犀如何完美融入时序数据库 TDengine 实现物联网数据流畅管理
本篇文章是“2024,我想和 TDengine 谈谈”征文活动的三等奖作品。文章从一个具体的业务场景出发,分析了企业在面对海量时序数据时的挑战,并提出了利用 TDengine 高效处理和存储数据的方法,帮助企业解决在数据采集、存储、分析等方面的痛点。通过这篇文章,作者不仅展示了自己对数据处理技术的理解,还进一步阐释了时序数据库在行业中的潜力与应用价值,为读者提供了很多实际的操作思路和技术选型的参考。
52 1
|
2月前
|
存储 Java easyexcel
招行面试:100万级别数据的Excel,如何秒级导入到数据库?
本文由40岁老架构师尼恩撰写,分享了应对招商银行Java后端面试绝命12题的经验。文章详细介绍了如何通过系统化准备,在面试中展示强大的技术实力。针对百万级数据的Excel导入难题,尼恩推荐使用阿里巴巴开源的EasyExcel框架,并结合高性能分片读取、Disruptor队列缓冲和高并发批量写入的架构方案,实现高效的数据处理。此外,文章还提供了完整的代码示例和配置说明,帮助读者快速掌握相关技能。建议读者参考《尼恩Java面试宝典PDF》进行系统化刷题,提升面试竞争力。关注公众号【技术自由圈】可获取更多技术资源和指导。
|
2月前
|
前端开发 JavaScript 数据库
获取数据库中字段的数据作为下拉框选项
获取数据库中字段的数据作为下拉框选项
64 5
|
2月前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。
|
2月前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
3月前
|
SQL 关系型数据库 数据库
国产数据实战之docker部署MyWebSQL数据库管理工具
【10月更文挑战第23天】国产数据实战之docker部署MyWebSQL数据库管理工具
270 4
国产数据实战之docker部署MyWebSQL数据库管理工具
|
3月前
|
关系型数据库 MySQL 数据库
GBase 数据库如何像MYSQL一样存放多行数据
GBase 数据库如何像MYSQL一样存放多行数据