仓酷云

标题: MSSQL教程之SQL 恢复手艺 [打印本页]

作者: 分手快乐    时间: 2015-1-16 22:30
标题: MSSQL教程之SQL 恢复手艺
恢复到之前的某个状态,是需要数据的。这数据可以是a)回滚步骤或者b)操作之前的数据状态原文。恢复SQLServer数据库文件恢复手艺
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
对于update操作,event中依次记录旧行,新行的值。
作者: 小魔女    时间: 2015-1-19 15:53
原来的计算字段其实和虚拟字段很像。只是管理方面好了而已,性能方面提高不多。但是SQL2005提供了计算字段的持久化,这就提高了查询的性能,但是会加重insert和update的负担。OLTP慎用。OLAP可以大规模使用。
作者: 飘灵儿    时间: 2015-1-24 13:51
以前的DTS轻盈简单。但是现在的SSIS虽然功能强大了很多,但是总是让人感觉太麻烦。看看论坛中询问SSIS的贴子就知道。做的功能太强大了,往往会有很多用户不会用了
作者: 蒙在股里    时间: 2015-2-1 16:20
SQL语言是学习所有数据库产品的基础,无论你是做数据库管理还是做数据库开发都是这样。不过具体学习的侧重点要看你将来做哪一块,如果是做数据库管理(DBA),侧重点应该放在SQLServer的系统管理上.
作者: 只想知道    时间: 2015-2-7 08:22
而SQLServer如果能像Oracle一样可以为登陆分配如:5%的cpu,10%的内存。就可以解决这个漏洞。
作者: 精灵巫婆    时间: 2015-2-21 06:18
多加的系统视图和实时系统信息这些东西对DBA挑优非常有帮助,但是感觉粒度还是不太细。
作者: 柔情似水    时间: 2015-3-6 19:57
发几份SQL课件,以飨阅者
作者: 小妖女    时间: 2015-3-20 16:24
如安全管理、备份恢复、性能监控和调优等,SQL只要熟悉基本操作就可以,只要程序设计部分只要稍加了解即可(如存储过程、触发器等)。




欢迎光临 仓酷云 (http://ckuyun.com/) Powered by Discuz! X3.2