求救:sql server 2005上附加数据库
客户的sql server 2005上业务数据库置疑,将mdf和ldf文件拷贝出来,然后删除数据库,无法附加数据库上去。
现只有客户的mdf和ldf数据文件,请教各位大虾,有没有办法附加成功,得到里面的业务数据。
参考了网上提供的sql server 2000的处理办法,无法成功。
能指导完成问题,马上给分。
问题点数:200、回复次数:27Top
1 楼fellowcheng(鹰击长空)回复于 2006-11-16 10:40:35 得分 0
路过Top
2 楼allright_flash()回复于 2006-11-16 10:42:13 得分 0
路径对不拉Top
3 楼pjy(古虫)回复于 2006-11-16 10:52:03 得分 0
路径没有错!Top
4 楼bulletCoderHope(九下九下做世界)回复于 2006-11-16 10:59:56 得分 0
sqlserver2000下附加数据库总能成功,sql2005就没用过Top
5 楼dawugui(潇洒老乌龟)回复于 2006-11-16 11:01:16 得分 0
下面的示例将 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'
Top
6 楼pjy(古虫)回复于 2006-11-16 11:05:17 得分 0
不行!Top
7 楼wangtiecheng(不知不为过,不学就是错!)回复于 2006-11-16 12:31:48 得分 0
--用sp_attach_single_file_db 试下
EXEC sp_attach_single_file_db @dbname = 'pubs',
@physname = 'c:\Program Files\Microsoft SQL Server\MSSQL\Data\pubs.mdf'
Top
8 楼pjy(古虫)回复于 2006-11-16 13:09:58 得分 0
试了,也不行!Top
9 楼dutguoyi(新鲜鱼排)回复于 2006-11-17 09:11:45 得分 0
I hope this message helpful.
http://community.csdn.net/Expert/topic/5122/5122922.xml?temp=.3182642Top
10 楼redsuki()回复于 2006-11-21 11:56:08 得分 0
2005没试过。Top
11 楼junmail(浪子)回复于 2006-11-21 17:30:23 得分 0
2005里面的附加和2000是一样的阿!
是不是搂主的数据文件受到损坏!Top
12 楼zhanminga(钻石之光)回复于 2006-11-21 18:03:16 得分 0
对于质疑的数据库不能直接附加Top
13 楼zhanminga(钻石之光)回复于 2006-11-21 18:05:50 得分 0
=====================================================
只有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
Top
14 楼zhanminga(钻石之光)回复于 2006-11-21 18:08:17 得分 0
你可以按照步骤一步一步走就ok了Top
15 楼happydreamer(www.sz.js.cn,www.gyxk.com)回复于 2006-11-22 13:42:07 得分 0
我试了一下在sql2005里面
A.我们使用默认方式建立一个供恢复使用的数据库(如test)。可以在SQL Server Enterprise Manager里面建立。
B.停掉数据库服务器。
C.将刚才生成的数据库的日志文件test_log.ldf删除,用要恢复的数据库mdf文件覆盖刚才生成的数据库数据文件test_data.mdf。
D.启动数据库服务器。
--此时数据库的状态正常,但数据库名左边的加号没有了,点击数据库无任何反映
2005和2000还是不太一样的Top
16 楼happydreamer(www.sz.js.cn,www.gyxk.com)回复于 2006-11-22 13:56:34 得分 0
另外sql2005增强的安全性,不允许通过
update sysdatabases set status=-32768 where dbid=DB_ID('dbname')
对系统目录进行即席更新
把数据库改为紧急模式这样操作
ALTER DATABASE dbname SET EMERGENCY
Top
17 楼jiangchuandong(岁月的流逝......)回复于 2006-11-23 19:26:50 得分 0
markTop
18 楼zhouzidane()回复于 2006-11-30 14:36:40 得分 0
2005和2000是一样的
有可能是你文件损坏了吧Top
19 楼xiaoku(野蛮人(^v^))回复于 2006-11-30 14:39:41 得分 0
up to uTop
20 楼laoliu666(鹅鹅鹅,曲项向天歌,白毛浮绿水,红掌拨清波。)回复于 2006-12-01 09:58:51 得分 0
学习并收藏Top
21 楼kellerxq(keller)回复于 2006-12-01 14:05:08 得分 0
引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 的默认临时数据库。)
Top
22 楼xx_adam(一无所有)回复于 2006-12-01 14:18:42 得分 0
是不是数据库文件损坏?Top
23 楼sr_www()回复于 2006-12-05 16:38:15 得分 0
晕`这玩意```Top
24 楼redsuki()回复于 2006-12-05 16:48:00 得分 0
可能数据库文件损坏了.
如果数据重要的话,可以找我恢复数据,你可以看下http://www.raidcn.netTop
25 楼fish_yht(百行孝为先,万业勤为径。)回复于 2006-12-05 20:19:28 得分 0
顶一下Top
26 楼shawnwan()回复于 2006-12-06 09:35:27 得分 0
学习下,对2005不熟悉Top
27 楼laoliu666(鹅鹅鹅,曲项向天歌,白毛浮绿水,红掌拨清波。)回复于 2006-12-07 16:49:24 得分 0
markTop




