English

速达软件
     
当前位置:速达软件 >> 技术支持 >> 浏览文章

SQL Server无日志恢复数据库

发布日期:2009年07月30日 浏览次数: 作者:佚名  

速达,管家婆,金碟用友等软件一样平常都是用SQL数据库,但假如我们不警惕将SQL日志文件删除,这时候数据库就会被破坏。其实,无日志文件SQL数据也是能恢复的。:&H^n Rx6aJ *"OE
方法如下:4@nDwlW?eNZ,Ok

数据库日志文件的误删或别的缘故原由引起数据库日志的损坏 A.b J8!*?SXj52o
  方法一cbR$hA9!QD9k=K

  1.新建一个同名的数据库n 6a@uy?Pn1J.n6 7h

  2.再停掉sql server(细致不要星散数据库)J#z_" 9X2JhXE~

  3.用原数据库的数据文件覆盖掉这个新建的数据库($W"E$bbVp7?QvfS

  4.再重启sql serverzE93!~O\B3N=I

  5.此时打开企业管理器时会出现置疑,先不管,实行下面的语句(细致修改其中的数据库名)tziQSYdh%"~uU€

  6.完成后一样平常就可以访问数据库中的数据了,这时,数据库自己一样平常还要题目,解决办法是,行使karS~:w}268 \$Md&

  数据库的脚本创建一个新的数据库,并将数据导进去就行了.$VTY!6KIk(#U.Ozj]

  USE MASTER_!#€Z{W}x|h7(s??H

  GO] _€ @\(Z0*a4m4

  SP_CONFIGURE 'ALLOW UPDATES',1 RECONFIGURE WITH OVERRIDEaKSe9v`=o6# ]~4U_

  GOT2wD]?/{:+ 4ZSN@\g

  UPDATE SYSDATABASES SET STATUS =32768 WHERE NAME='置疑的数据库名'WmUtpkqrNUGW^\-mQ

  GouiEP+]W1cIz/Ojzn3

  sp_dboption '置疑的数据库名', 'single user', 'true']h@4,:j #H JzPQ€

  Go5D"!,k(:1)a5:?,PFo

  DBCC CHECKDB('置疑的数据库名') d!4\q} €]os. 

  Go&uzm ]OwoGVW;PiL

  update sysdatabases set status =28 where name='置疑的数据库名'u}r!?aC$(x0

  God6UoQ1riInlr'S3~

  sp_configure 'allow updates', 0 reconfigure with overrideDXH.0{L@K1C4rrs 4

  Go@lA V 7ijzF~Pl

  sp_dboption '置疑的数据库名', 'single user', 'false'\jBn!X`}[rcq7N#Njs

  GoR0K3M |A\jX#){2E

  方法二AhB3=#}B@9g)9cNi=

  事情的原由- |B€):I84/$

  昨天,体系管理员告诉我,我们一个内部应用数据库所在的磁盘空间不足了。我细致到数据库事件日志文件XXX_Data.ldf文件已经增加到了3GB,于是我决意缩小这个日志文件。经过收缩数据库等操作未果后,我犯了一个自进入行业以来的最大最愚笨的错误:竟然误删除了这个日志文件!后来我看到所有论及数据库恢复的文章上都说道:“无论如何都要保证数据库日志文件存在,它至关紧张”,甚至微软甚至有一篇KB文章讲如何只靠日志文件恢复数据库的。我真是不知道我那时候是怎么想的?!h2'[&9~.5xB/|V

  这下子坏了!这个数据库连不上了,企业管理器在它的旁边写着“(置疑)”。而且最要命的,这个数据库从来没有备份了。我唯一找得到的是迁移半年前的另外一个数据库服务器,应用倒是能用了,但是少了很多记录、表和存储过程。真盼望这只是一场噩梦!;utT^!4d/s /j|N

  没有用果的恢复步骤xESe"J$ gFi3U(

  附加数据库\1w u?mxdn}E'tV=

  _Rambo讲过被删除日志文件中不存在运动日志时,可以这么做来恢复: y;}V/3KApc€Zp\u2

  1,星散被置疑的数据库,可以使用sp_detach_db=UJYpuE{m-)#A

  2,附加数据库,可以使用sp_attach_single_file_dbnE6;~5.&j\r$*[8)3

  但是,很遗憾,实行之后,SQL Server质疑数据文件和日志文件不符,所以无法附加数据库数据文件。W8wLl+-%qG~HOa2E0

  DTS数据导出]5zPR\L' ^p0,DVK

  不行,无法读取XXX数据库,DTS Wizard报告说“初始化上下文发生错误”。=pZJH\ o?]tgLu0Z

  紧急模式H#M@jS= a1nENf`

  怡红公子讲过没有日志用于恢复时,可以这么做:LS{ wG((u€€6/IbzB

  1,把数据库设置为emergency mode)n*-z,wd=Lhs 5s

  2,重新建立一个log文件yDglGPd4T?jcuah

  3,把SQL Server 重新启动一下J:GAFWWxLH@yeqZY

  4,把应用数据库设置成单用户模式rk UngeE9w9 ,e

  5,做DBCC CHECKDBzx_;OAq=B)%oup-_*`

  6,假如没有什么大题目就可以把数据库状况改回去了,记得别忘了把体系表的修改选项关掉NNbE~n ???6 [b;

  我实践了一下,把应用数据库的数据文件移走,重新建立一个同名的数据库XXX,然后停掉SQL服务,把原来的数据文件再覆盖回来。之后,按照怡红公子的步骤走。X~+|\?$3aks"| t 

  但是,也很遗憾,除了第2步之外,其他步骤实行特别很是成功。可惜,重启SQL Server之后,这个应用数据库仍然是置疑!uz` O*3;iGOI7`GMG

  不过,让我欣慰的是,这么做之后,倒是能够Select数据了,让我大出一口气。只不过,组件使用数据库时,报告说:“发生错误:-2147467259,未能在数据库 'XXX' 中运行 BEGIN TRANSACTION,由于该数据库处于回避恢复模式。”!bZZ]DZtdSeJ#xni

  最终成功恢复的悉数步骤8€GJ7fjCB~}rz"€

  设置数据库为紧急模式wXxny"-COxq'53x(

  停掉SQL Server服务;" \x_o StxqNV{HQk6

  把应用数据库的数据文件XXX_Data.mdf移走;a1kxwY`kU+Gjm#;Y

  重新建立一个同名的数据库XXX;Sr2Uax=%?l3dU-}}CV

  停掉SQL服务;KZv `B$? -€Gk

  把原来的数据文件再覆盖回来;:%p&![8zFeV nxY8"

  运行以下语句,把该数据库设置为紧急模式;(?q?3G,-T;iTi-dG

  运行“Use Master[]5Ot$QI7akP?,u@`{

  Go6 ?[n8e 14 eG4=

  sp_configure 'allow updates', 1 ]M-BU\bxS"n\7mN

  reconfigure with override7=f,f*?8)K0l2n'j

  Go”.1R-6C?#IMw kj9!ATWN

  实行效果:G?F.?I,Re5cYnd h6&

  DBCC 实行完毕。假如 DBCC 输出了错误信息,请与体系管理员联系。€oBu5)9BF9Z el?G

  已将配置选项 'allow updates' 从 0 改为 1。请运行 RECONFIGURE 语句以安装。M \wd49&b:DIA[B

  接着运行“update sysdatabases set status = 32768 where name = 'XXX'”Hx=+G1'LA8HV'M

  实行效果:WfJo 0\41#vQL

  (所影响的行数为 1 行)&6Bd{y'Q|8L{~

  重启SQL Server服务; 169R5Ph_T va} XG

  运行以下语句,把应用数据库设置为Single User模式;F]uHY€z= m [z =[

  运行“sp_dboption 'XXX', 'single user', 'true'”n?as,.=v?TU Q}danu

  实行效果:),\[Xi$~La[IUg+

  饬令已成功完成。CL[d{72~2U P!J

  ü 做DBCC CHECKDB;c+!c#n#sM:WG?=ld|j

  运行“DBCC CHECKDB('XXX')”Q|s\"{z5V#l=`m:o

  实行效果:Wm@@(-[Ts*€FPs?U]

  'XXX' 的 DBCC 效果。? |%NeCR| &A)$0P

  'sysobjects' 的 DBCC 效果。|Lrvb,?teMz|4L]W=R&

  对象 'sysobjects' 有 273 行,这些行位于 5 页中。ep Ah @NNe1KR%o

  'sysindexes' 的 DBCC 效果。1?\~Kk(!n$f4B

  对象 'sysindexes' 有 202 行,这些行位于 7 页中。 Q20'gSA7m\HNx+Z\`

  'syscolumns' 的 DBCC 效果。KW%=m Sp5&JTO+gQ^G

  ………-M)! yn#?Z43I*C'

  ü 运行以下语句把体系表的修改选项关掉;TJ]me} S@jqF"5ZE(

  运行“sp_resetstatus "XXX":4]( _:]&tZOs7

  go6QL,uZ€F&f"2 Q$= An

  sp_configure 'allow updates', 0Pg9Gx3iWK0W.p{

  reconfigure with override9Qr=o9?woZ6€bu)~

  Go”€o\#~T5*(HiYI nj

  实行效果:/*r*1cu9\dQu_^ :X

  在 sysdatabases 中更新数据库 'XXX' 的条款之前,模式 = 0,状况 = 28(状况 suspect_bit = 0),.9-^ Qp6R0 [

  没有更新 sysdatabases 中的任何行,由于已精确地重置了模式和状况。没有错误,未进行任何更改。 AehgOLx:@ e)1@S

  DBCC 实行完毕。假如 DBCC 输出了错误信息,请与体系管理员联系。3B!U4foxp4 e1

  已将配置选项 'allow updates' 从 1 改为 0。请运行 RECONFIGURE 语句以安装。W@]5$c*g-8}Qm+c

  重新建立另外一个数据库XXX.Lost;R6,+I]-Q ^y1DUXb

  DTS导出领导h_vp"&])MG=e($we;UKU

  运行DTS导出领导;F;pd3a@?d'€l7Agaa

  复制源选择EmergencyMode的数据库XXX,导入到XXX.Lost;)p$f}9=cRs|tMS%

  选择“在SQL Server数据库之间复制对象和数据”,试了多次,彷佛不行,只是复制过来了所有表结构,但是没稀有据,也没有视图和存储过程,而且DTS领导最后报告复制失败;pB%?zRC?7$~dmZ

  所以最后选择“从源数据库复制表和视图”,但是后来发现,如许总是只能复制一部分表记录;XV)f%=Le"MUlDYZS

  于是选择“用一条查询指定要传输的数据”,缺哪个表记录,就导哪个;O(\kf)OWfZ+Jr

  视图和存储过程是实行SQL语句添加的。Cn)}G\B€mP`Zeqz3 z

  维护Sql Server中表的索引q€w|'1|@6- 4#jH

  在使用和创建数据库索引中经常会遇到一些题目,在这里可以采用一些另类的方法解决… 1RjP_ sXr^Z;

  --第一步:查看是否必要维护,查看扫描密度/Scan Density是否为100%I9M?XZgQ. 3tb€ y

  declare @table_id intazU~iP^FTn_j*{)4oc

  set @table_id=object_id('表名')uj v__IG^ m1 *8qV

  dbcc showcontig(@table_id)Kz]G#FW5%f

  --第二步:重构表索引2C*]atykim}-U/?xrf.

  dbcc dbreindex('表名',pk_索引名,100)_-4O=~Ta_@€/r.'

  --重做第一步,如发现扫描密度/Scan Density照旧小于100%则重构表的所有索引.- %Xd$DY9 ]AH

  --并不肯定能达100%。ujMtFT Eo(KX$#

  dbcc dbreindex('表名','',100)GnB((rXy`Y0`Hbp+h
U,slo%.C2=4?wf

[版权归原作者及coolcxm共同拥有,转载请注明出处]
 
上一篇:SQL Server数据库维护计划 下一篇:3000系列V8.65新增功能和改正的错误.