求救:sql server 2005上附加数据库 200CSDN]

发布时间:2016-12-7 22:29:20 编辑:www.fx114.net 分享查询网我要评论
本篇文章主要介绍了"求救:sql server 2005上附加数据库 200CSDN]",主要涉及到求救:sql server 2005上附加数据库 200CSDN]方面的内容,对于求救:sql server 2005上附加数据库 200CSDN]感兴趣的同学可以参考一下。

客户的sql server 2005上业务数据库置疑,将mdf和ldf文件拷贝出来,然后删除数据库,无法附加数据库上去。 现只有客户的mdf和ldf数据文件,请教各位大虾,有没有办法附加成功,得到里面的业务数据。 参考了网上提供的sql server 2000的处理办法,无法成功。 能指导完成问题,马上给分。

路过

路径对不拉

路径没有错!

sqlserver2000下附加数据库总能成功,sql2005就没用过

下面的示例将 pubs 中的两个文件附加到当前服务器。 EXEC sp_attach_db @dbname = N'pubs',     @filename1 = N'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs.mdf',     @filename2 = N'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs_log.ldf'

不行!

--用sp_attach_single_file_db 试下 EXEC sp_attach_single_file_db @dbname = 'pubs',     @physname = 'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs.mdf'

试了,也不行!

I hope this message helpful. http://community.csdn.net/Expert/topic/5122/5122922.xml?temp=.3182642

2005没试过。

2005里面的附加和2000是一样的阿! 是不是搂主的数据文件受到损坏!

对于质疑的数据库不能直接附加

===================================================== 只有mdf文件的恢复技术 ===================================================== 由于种种原因,我们如果当时仅仅备份了mdf文件,那么恢复起来就是一件很麻烦的事情了。 如果您的mdf文件是当前数据库产生的,那么很侥幸,也许你使用sp_attach_db或者sp_attach_single_file_db可以恢复数据库, 但是会出现类似下面的提示信息 设备激活错误。物理文件名 'C:\Program Files\Microsoft SQL Server\MSSQL\data\test_Log.LDF' 可能有误。 已创建名为 'C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_log.LDF' 的新日志文件。 但是,如果您的数据库文件是从其他计算机上复制过来的,那么很不幸,也许上述办法就行不通了。你也许会得到类似下面的错误信息 服务器: 消息 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 Files\Microsoft SQL Server\MSSQL\Data\test_log.ldf') 执行过程中,如果遇到下列提示信息: 服务器: 消息 5030,级别 16,状态 1,行 1 未能排它地锁定数据库以执行该操作。 DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。[brown][/i] 说明您的其他程序正在使用该数据库,如果刚才您在F步骤中使用SQL Server Enterprise Manager打开了test库的系统表,那么退出SQL Server Enterprise Manager就可以了。 正确执行完成的提示应该类似于: 警告: 数据库 'test' 的日志已重建。已失去事务的一致性。应运行 DBCC CHECKDB 以验证物理一致性。将必须重置数据库选项,并且可能需要删除多余的日志文件。 DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。 此时打开在SQL Server& nbsp;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

你可以按照步骤一步一步走就ok了

我试了一下在sql2005里面 A.我们使用默认方式建立一个供恢复使用的数据库(如test)。可以在SQL Server Enterprise Manager里面建立。 B.停掉数据库服务器。 C.将刚才生成的数据库的日志文件test_log.ldf删除,用要恢复的数据库mdf文件覆盖刚才生成的数据库数据文件test_data.mdf。 D.启动数据库服务器。 --此时数据库的状态正常,但数据库名左边的加号没有了,点击数据库无任何反映 2005和2000还是不太一样的

另外sql2005增强的安全性,不允许通过 update sysdatabases set status=-32768 where dbid=DB_ID('dbname') 对系统目录进行即席更新 把数据库改为紧急模式这样操作 ALTER DATABASE dbname SET EMERGENCY

mark

2005和2000是一样的 有可能是你文件损坏了吧

up to u

学习并收藏

引MS官方的文章http://support.microsoft.com/kb/909967/zh-cn中的一段话。 备份数据 您可能希望按照当前的状态保存某些数据库。可能还希望保存对默认数据库所做的更改。如果存在上述任一情况,请确保对数据进行了完好备份,然后再按照本文中的步骤操作。或者,保存所有数据和所有日志文件的副本。将这些副本保存到 MSSQL 文件夹以外的文件夹。在卸载过程中,MSSQL 文件夹将被删除。 您必须保存的文件包括下列数据库文件。这些文件作为 SQL Server 2005 的一部分安装: • Distmdl.*  • Master.*  • Mastlog.*  • Model.*  • Modellog.*  • Msdbdata.*  • Msdblog.*  • Mssqlsystemresource.*  • Northwnd.*(该数据库的安装是可选的。)   • Pubs.*  • Pubs_log.*  • Tempdb.*  • Templog.*  • ReportServer[$InstanceName](这是 Report Server 的默认数据库。)   • ReportServer[$InstanceName]TempDB(这是 Report Server 的默认临时数据库。)  

是不是数据库文件损坏?

晕`这玩意```

可能数据库文件损坏了. 如果数据重要的话,可以找我恢复数据,你可以看下http://www.raidcn.net

顶一下

学习下,对2005不熟悉

mark

上一篇:急::数据库镜像,故障转移,备份 日志传递的问题 20CSDN]
下一篇:how to search objects in sql server 2005? 20CSDN]

相关文章

相关评论