CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
不看会后悔的Windows XP之经验谈 简单快捷DIY实用家庭影院
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  MS-SQL Server >  新技术前沿

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

楼主pjy(古虫)2006-11-16 10:13:41 在 MS-SQL Server / 新技术前沿 提问

客户的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

相关问题

关键词

得分解答快速导航

  • 帖主:pjy

相关链接

  • SQL Server类图书

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
北京创新乐知广告有限公司 版权所有, 京 ICP 证 070598 号
世纪乐知(北京)网络技术有限公司 提供技术支持
Copyright © 2000-2008, CSDN.NET, All Rights Reserved
GongshangLogo