仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 791|回复: 7
打印 上一主题 下一主题

[学习教程] MSSQL教程之怎样恢复和修复MS SQL数据库的MDF文件

[复制链接]
小女巫 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-16 22:24:13 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
MySQL这个名字是怎么来的已经不清楚了。基本指南和大量的库和工具带有前缀“my”已经有10年以上,而且不管怎样,MySQLAB创始人之一的的女儿也叫My。恢复|数据|数据库假如备份的数据库有2个文件,分离是.LDF和.MDF,翻开企业办理器,在实例上右击---一切义务--附加数据库,然后选择谁人.MDF文件,就能够了。  大概在查询剖析器中输出:
  sp_attach_db"数据库称号","路径文件名.ldf","路径文件名.MDF"
  SQLServer数据库备份有两种体例,一种是利用BACKUPDATABASE将数据库文件备份进来,别的一种就是间接拷贝数据库文件mdf和日记文件ldf的体例。上面将次要会商一下后者的备份与恢复。本文假定您能纯熟利用SQLServerEnterpriseManager(SQLServer企业办理器)和SQLServerQuweyAnalyser(SQLServer查询剖析器)
  1、一般的备份、恢复体例
  一般体例下,我们要备份一个数据库,起首要先将该数据库从运转的数据服务器中止开,大概停失落全部数据库服务器,然后复制文件。
  卸下数据库的命令:Sp_detach_db数据库名
  毗连数据库的命令:Sp_attach_db大概sp_attach_single_file_db
  s_attach_db[@dbname=]dbname,[@filename1=]filename_n[,...16]
  sp_attach_single_file_db[@dbname=]dbname,[@physname=]physical_name
  利用此办法能够准确恢复SQLSever7.0和SQLServer2000的数据库文件,要点是备份的时分必定要将mdf和ldf两个文件都备份上去,mdf文件是数据库数据文件,ldf是数据库日记文件。
  例子:
  假定数据库为test,其数据文件为test_data.mdf,日记文件为test_log.ldf。上面我们会商一下怎样备份、恢复该数据库。
  卸下数据库:sp_detach_dbtest
  毗连数据库:sp_attach_dbtest,C:ProgramFilesMicrosoftSQLServerMSSQLData        est_data.mdf,C:ProgramFilesMicrosoftSQLServerMSSQLData        est_log.ldf
  sp_attach_single_file_dbtest,C:ProgramFilesMicrosoftSQLServerMSSQLData        est_data.mdf
  //本文转自C++Builder研讨-http://www.ccrun.com/article.asp?i=986&d=oxit07
  2、只要mdf文件的恢复手艺
  因为各种缘故原由,我们假如事先仅仅备份了mdf文件,那末恢复起来就是一件很贫苦的事变了。
  假如您的mdf文件是以后数据库发生的,那末很幸运,大概你利用sp_attach_db大概sp_attach_single_file_db能够恢单数据库,可是会呈现相似上面的提醒信息
  设备激活毛病。物理文件名C:ProgramFilesMicrosoftSQLServerMSSQLdata        est_Log.LDF大概有误。
  已创立名为C:ProgramFilesMicrosoftSQLServerMSSQLData        est_log.LDF的新日记文件。
  可是,假如您的数据库文件是从其他盘算机上复制过去的,那末很不幸,大概上述举措就行欠亨了。你大概会失掉相似上面的毛病信息
  服务器:动静1813,级别16,形态2,行1
  未能翻开新数据库test。CREATEDATABASE将停止。
  设备激活毛病。物理文件名d:        est_log.LDF大概有误。
 怎样办呢?别发急,上面我们举例申明恢复举措。
  A.我们利用默许体例创建一个供恢复利用的数据库(如test)。能够在SQLServerEnterpriseManager内里创建。
  B.停失落数据库服务器。
  C.将方才天生的数据库的日记文件test_log.ldf删除,用要恢复的数据库mdf文件掩盖方才天生的数据库数据文件test_data.mdf。
  D.启动数据库服务器。此时会看到数据库test的形态为“置疑”。这时候候不克不及对此数据库举行任何操纵。
  E.设置数据库同意间接操纵体系表。此操纵能够在SQLServerEnterpriseManager内里选择数据库服务器,按右键,选择“属性”,在“服务器设置”页面中将“同意对体系目次间接修正”一项选中。也能够利用以下语句来完成。
以下是援用片断:
  usemaster
  go
  sp_configureallowupdates,1
  go
  reconfigurewithoverride
  go
  F.设置test为告急修复形式
  updatesysdatabasessetstatus=-32768wheredbid=DB_ID(test)
  此时能够在SQLServerEnterpriseManager内里看到该数据库处于“只读置疑脱机告急形式”能够看到数据库内里的表,可是仅唯一体系表
  G.上面实行真实的恢复操纵,重修数据库日记文件
  dbccrebuild_log(test,C:ProgramFilesMicrosoftSQLServerMSSQLData        est_log.ldf)
  实行过程当中,假如碰到以下提醒信息:
  服务器:动静5030,级别16,形态1,行1
  未能排它地锁定命据库以实行该操纵。
  DBCC实行终了。假如DBCC输入了毛病信息,请与体系办理员接洽。
  申明您的其他程序正在利用该数据库,假如方才您在F步骤中利用SQLServerEnterpriseManager翻开了test库的体系表,那末加入SQLServerEnterpriseManager就能够了。
  准确实行完成的提醒应当相似于:
  告诫:数据库test的日记已重修。已得到事件的分歧性。应运转DBCCCHECKDB以考证物理分歧性。将必需重置数据库选项,而且大概必要删除过剩的日记文件。
  DBCC实行终了。假如DBCC输入了毛病信息,请与体系办理员接洽。
  此时翻开在SQLServerEnterpriseManager内里会看到数据库的形态为“只供DBO利用”。此时能够会见数据库内里的用户表了。
  H.考证数据库分歧性(可省略)
  dbcccheckdb(test)
 一样平常实行了局以下:
  CHECKDB发明了0个分派毛病和0个分歧性毛病(在数据库test中)。
  DBCC实行终了。假如DBCC输入了毛病信息,请与体系办理员接洽。
  I.设置数据库为一般形态
  sp_dboptiontest,dbouseonly,false
  假如没有堕落,那末祝贺,如今就能够一般的利用恢复后的数据库啦。
  J.最初一步,我们要将步骤E中设置的“同意对体系目次间接修正”一项恢复。由于平常间接操纵体系表是一件对照伤害的事变。固然,我们能够在SQLServerEnterpriseManager内里恢复,也能够利用以下语句完成
以下是援用片断:
  sp_configureallowupdates,0
  go
  reconfigurewithoverride
  go


两个到底是哪一个给出了MySQL这个名字至今依然是个迷,包括开发者在内也不知道。
若相依 该用户已被删除
沙发
发表于 2015-1-19 10:53:24 | 只看该作者
如果处理少量数据,比如几百条记录的数据,我不知道这两种情况哪个效率更高,如果处理大量数据呢?比如有表中有20万条记录.
因胸联盟 该用户已被删除
板凳
发表于 2015-1-26 20:31:17 | 只看该作者
从项目平台的选择上讲,我们关心的,应该是一款产品能不能满足任务需求,而不是网上怎么说。
深爱那片海 该用户已被删除
地板
发表于 2015-2-4 20:55:01 | 只看该作者
原来的计算字段其实和虚拟字段很像。只是管理方面好了而已,性能方面提高不多。但是SQL2005提供了计算字段的持久化,这就提高了查询的性能,但是会加重insert和update的负担。OLTP慎用。OLAP可以大规模使用。
只想知道 该用户已被删除
5#
发表于 2015-2-10 09:31:16 | 只看该作者
原来公司用过MYSQL自己也只是建个表写个SQL
活着的死人 该用户已被删除
6#
发表于 2015-3-1 07:54:11 | 只看该作者
财务软件要用SQL也只是后台的数据库而已,软件都是成品的,当然多学东西肯定是有好处的..
分手快乐 该用户已被删除
7#
发表于 2015-3-10 13:10:55 | 只看该作者
你可以简单地认为适合的就是好,不适合就是不好。
不帅 该用户已被删除
8#
发表于 2015-3-17 08:09:34 | 只看该作者
一个百万级别的基本信息表A,一个百万级别的详细记录表B,A中有个身份证id,B中也有身份id;先要找出A中在B的详细记录。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-12-23 05:06

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表