当前位置:首页>>开发编程>>数据库>>新闻内容  |虚拟主机 主机托管
SQL Server 2005日志文件损坏的处理方法
作者: 发布时间:2008-6-4 16:10:01 | 【字体:

  在实际的工作和学习中,许多人的SQL Server 2005数据库日志文件可能会发生损坏,例如硬件故障、计算机非正常重启或关机等等。

  在SQL Server 2005的日志文件损坏时,你会发现以下的情况:

  ◆1、在SQL Server Management Studio中显示数据库处于置疑(suspect)状态。

  ◆2、事件日志可能会出现如下错误信息:

  Could not redo log record (21737:686:9), for transaction ID (0:2334886), on page (1:37527), database 'Test' (database ID 15). Page: LSN = (21735:299:5), type = 2. Log: OpCode = 3, context 19, PrevPageLSN: (21737:615:1). Restore from a backup of the database, or repair the database.

  During redoing of a logged operation in database 'Test', an error occurred at log record ID (76116:286:2). Typically, the specific failure is previously logged as an error in the Windows Event Log service. Restore the database from a full backup, or repair the database.

  ◆3、无法分离数据库

  ◆4、用CREATE DATABASE DBName ON ( FILENAME = N'DBFile' ) FOR ATTACH_REBUILD_LOG附加数据库时出现提示:The log cannot be rebuilt because the database was not cleanly shut down.

  详细的恢复方法:

  1、停止数据库服务。

  2、将需要恢复的数据库文件复制到另外的位置。

  3、启动数据库服务。

  4、确认要恢复的数据库文件已经成功复制到另外的位置,然后在SQL Server Management Studio中删除要恢复的数据库。

  5、新建同名的数据库(数据库文件名也要相同)。

  6、停止数据库服务。

  7、用第2步中备份的.mdf文件覆盖新数据库的同名文件。

  8、启动数据库服务。

  9、运行alter database dbname set emergency,将数据库设置为emergency mode

  10、运行下面的命令就可以恢复数据库:

  use master

  declare @databasename varchar(255)

  set @databasename='要恢复的数据库名称'

  exec sp_dboption @databasename, N'single', N'true' --将目标数据库置为单用户状态

  dbcc checkdb(@databasename,REPAIR_ALLOW_DATA_LOSS)

  dbcc checkdb(@databasename,REPAIR_REBUILD)

  exec sp_dboption @databasename, N'single', N'false'--将目标数据库置为多用户状态

  注:这个方法是通过.mdf文件恢复数据库,即使大家的log文件丢失也可以进行恢复。


文章来源:
·教你安全配置SQL Server 2000数据库
·如何在Windows XP上安装SQL Server 2000
·SQL Server数据库从2000还原为2005的步骤
·SQL Server数据库还原的SQL语句及操作
·SQL Server 2000导入SQL Server 2005生成脚本的问题
·在SQL Server 2005下还原数据库的一个错误解决
·在SQL Server 2005新建用户出15195错误
·如何在SQL Server 2005中为安装程序增加计数器注册表项值
·快速的查出SQL Server 2005全部数据字典
 放生
 愚爱
 够爱
 触电
 白狐
 葬爱
 光荣
 画心
 火花
 稻香
 小酒窝
 下雨天
 右手边
 安静了
 魔杰座
 你不像她
 边做边爱
 擦肩而过
 我的答铃
 怀念过去
 等一分钟
 放手去爱
 冰河时代
 你的承诺
 自由飞翔
 原谅我一次
 吻的太逼真
 左眼皮跳跳
 做你的爱人
 一定要爱你
 飞向别人的床
 爱上别人的人
 感动天感动地
 心在跳情在烧
 玫瑰花的葬礼
 有没有人告诉你
 即使知道要见面
 爱上你是一个错
 最后一次的温柔
 爱上你是我的错
 怎么会狠心伤害我
 不是因为寂寞才想
 亲爱的那不是爱情
 难道爱一个人有错
 寂寞的时候说爱我