MSSQL编程:SQL Server 只要mdf文件,告急修复-
恢复到之前的某个状态,是需要数据的。这数据可以是a)回滚步骤或者b)操作之前的数据状态原文。server数据库有2个文件,分离是Mall_DataBase_Log.LDF和Mall_DataBase_Log.MDF但是我不晓得怎样使这个网站在我电脑上运转!
我刚装了mssql2000!
翻开企业办理器,在实例上右击---一切义务--附加数据库
然后选择下面你所说的数据文件,就能够了。
sp_attach_db"数据库称号","路径Mall_database_log.ldf","路径Mall_Database_log.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
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
Archive非常适合存储大量的独立的,作为历史记录的数据。因为它们不经常被读取。Archive拥有高效的插入速度,但其对查询的支持相对较差 比如,MicrosoftSQLServer2008的某一个版本可以满足现在的这个业务的需要,而且价格还比Oracle11g要便宜,那么这一产品就是适合的。 SP4包括用于以下SQLServer2000组件的程序包:Database组件(下载文件:SQL2000-KB884525-SP4-x86.EXE)更新SQLServer2000的32位Database组件,包括数据库引擎、复制、客户端连接组件及工具。有关其他信息,请参阅ReadmeSql2k32Sp4.htm。AnalysisServices组件(下载文件:SQL2000.AS-KB884525-SP4-x86.EXE)更新SQLServer2000的32位AnalysisServices。 比如日志传送、比如集群。。。 SQLServer的异构移植功能个人感觉最好了。(如果对比过SQLServer的链接服务器和Oracle的透明网关的朋友会发现SQLServer的sp_addlinkedserver(openquery)异构数据库系列比Oracle真是强太多了。) 我们学到了什么?思考问题的时候从表的角度来思考问 语句级快照和事务级快照终于为SQLServer的并发性能带来了突破。个人感觉语句级快照大家应该应用。事务级快照,如果是高并发系统还要慎用。如果一个用户总是被提示修改不成功要求重试时,会杀人的! 同样会为索引视图等应用带来麻烦。看看行级和事务级的快照数据放在tempdb中,就能感觉到目前架构的尴尬。 对一张百万级别的表建游标,同时又没有什么过滤条件,取得游标效率是如果直接SQL查询百万条数据;如果再对每条记录做处理,耗时将更长。
页:
[1]