MSSQL无数据库日志文件恢复数据库方法两则


   步骤一

  1.新建一个同名的数据库

  2.再停掉sql server( 留神不要 拆散数据库)

  3.用原数据库的数据文件 遮蔽掉这个新建的数据库

  4.再重启sql server

  5.此时 打开企业治理器时会浮现置疑,先 无论,执行下面的语句( 留神 批改其中的数据库名)

  6. 实现后普通就 可以 拜访数据库中的数据了,这时,数据库 本身普通还要问题,解决 步骤是,利用
  数据库的脚本 缔造一个新的数据库,并将数据导进去就行了.

  USE MASTER
  GO

  SP_CONFIGURE 'ALLOW UPDATES',1 RECONFIGURE WITH OVERRIDE
  GO

  UPDATE SYSDATABASES SET STATUS =32768 WHERE NAME='置疑的数据库名'
  Go

  sp_dboption '置疑的数据库名', 'single user', 'true'
  Go

  DBCC CHECKDB('置疑的数据库名')
  Go

  update sysdatabases set status =28 where name='置疑的数据库名'
  Go

  sp_configure 'allow updates', 0 reconfigure with override
  Go

  sp_dboption '置疑的数据库名', 'single user', 'false'
  Go

   步骤二

   事件的起因
  昨天,系统治理员告诉我,我们一个内部 利用数据库所在的磁盘空间缺乏了 。我 留神到数据库事件日志文件XXX_Data.ldf文件已经增进到了3GB,于是我决意缩短这个日志文件 。 通过收缩数据库等操作未果后,我犯了一个自进入行业以来的最大最 愚昧的 舛误:居然误删除了这个日志文件!后来我看到所有论及数据库 复原的文章上都说道:“无论如何都要 保障数据库日志文件存在,它至关主要”,甚至微软甚至有一篇KB文章讲如何只靠日志文件 复原数据库的 。我真是不晓得我那时候是怎么想的?!

  这下子坏了!这个数据库连不上了,企业治理器在它的旁边写着“(置疑)” 。并且最要命的,这个数据库 向来没有备份了 。我唯一找得到的是 迁徙半年前的另外一个数据库服务器, 利用倒是能用了,然而少了许多记录、表和存储过程 。真 盼望这只是一场噩梦!

  没有 动机的 复原步骤
  附加数据库
  _Rambo讲过被删除日志文件中不存在 运动日志时, 可以这么做来 复原:

  1, 拆散被置疑的数据库, 可以 使用sp_detach_db
  2,附加数据库, 可以 使用sp_attach_single_file_db

  然而,很遗憾,执行之后,SQL Server质疑数据文件和日志文件不符,所以 无奈附加数据库数据文件 。

  DTS数据导出
  不行, 无奈读取XXX数据库,DTS Wizard报告说“初始化上下文 产生 舛误” 。

  紧急模式
  怡红公子讲过没有日志用于 复原时, 可以这么做:

  1,把数据库设置为emergency mode

  2,再一次 构建一个log文件

  3,把SQL Server 再一次启动一下

  4,把 利用数据库设置成单消费者模式

  5,做DBCC CHECKDB

  6,假如没有什么大问题就 可以把数据库状态改回去了,记得别忘了把系统表的 批改选项关掉

  我 实际了一下,把 利用数据库的数据文件移走,再一次 构建一个同名的数据库XXX, 而后停掉SQL服务,把原来的数据文件再 遮蔽回来 。之后,依照怡红公子的步骤走 。

  然而,也很遗憾,除了第2步之外, 其余步骤执行十分 顺利 。惋惜,重启SQL Server之后,这个 利用数据库 依旧是置疑!

  不过,让我 快慰的是,这么做之后,倒是 可以Select数据了,让我大出一口气 。只是,组件 使用数据库时,报告说:“ 产生 舛误:-2147467259,未能在数据库 'XXX' 中运行 BEGIN TRANSACTION,由于该数据库处于回避 复原模式 。”

  最终 顺利 复原的所有步骤
  设置数据库为紧急模式
  停掉SQL Server服务;
  把 利用数据库的数据文件XXX_Data.mdf移走;
  再一次 构建一个同名的数据库XXX;
  停掉SQL服务;
  把原来的数据文件再 遮蔽回来;
  运行以下语句,把该数据库设置为紧急模式;
  运行“Use Master
  Go
  sp_configure 'allow updates', 1
  reconfigure with override
  Go”

  执行 后果:
  DBCC 执行 结束 。假如 DBCC 输出了 舛误信息,请与系统治理员 联络 。
  已将配置选项 'allow updates' 从 0 改为 1 。请运行 RECONFIGURE 语句以安装 。

  接着运行“update sysdatabases set status = 32768 where name = 'XXX'”
  执行 后果:
  (所影响的行数为 1 行)

  重启SQL Server服务;

  运行以下语句,把 利用数据库设置为Single User模式;

  运行“sp_dboption 'XXX', 'single user', 'true'”

  执行 后果:

  命令已 顺利 实现 。

  做DBCC CHECKDB;

  运行“DBCC CHECKDB('XXX')”

  执行 后果:

  'XXX' 的 DBCC 后果 。

  'sysobjects' 的 DBCC 后果 。

  对象 'sysobjects' 有 273 行,这些行位于 5 页中 。

  'sysindexes' 的 DBCC 后果 。

  对象 'sysindexes' 有 202 行,这些行位于 7 页中 。

  'syscolumns' 的 DBCC 后果 。

  ………

  运行以下语句把系统表的 批改选项关掉;

  运行“sp_resetstatus "XXX"

  go

  sp_configure 'allow updates', 0

  reconfigure with override

  Go”

  执行 后果:

  在 sysdatabases 中更新数据库 'XXX' 的条目之前,模式 = 0,状态 = 28(状态 suspect_bit = 0),

  没有更新 sysdatabases 中的任何行,由于已正确地重置了模式和状态 。没有 舛误,未进行任何更改 。

  DBCC 执行 结束 。假如 DBCC 输出了 舛误信息,请与系统治理员 联络 。

  已将配置选项 'allow updates' 从 1 改为 0 。请运行 RECONFIGURE 语句以安装 。

  再一次 构建另外一个数据库XXX.Lost;

  DTS导出向导
  运行DTS导出向导;

  复制源 取舍EmergencyMode的数据库XXX,导入到XXX.Lost;

   取舍“在SQL Server数据库中间复制对象和数据”,试了 频繁, 如同不行,只是复制过来了所有表 构造,然而没有数据,也没有视图和存储过程,并且DTS向导最终报告复制失败;

  所以最终 取舍“从源数据库复制表和视图”,然而后来发现,这样总是不得不复制一 部分表记录;

  于是 取舍“用一条 查问指定要传输的数据”,缺哪个表记录,就导哪个;

  视图和存储过程是执行SQL语句增加的 。

  这样,XXX.Lost数据库就 可以替换原来的 利用数据库了