MSSQL无数据库日志文件恢复数据库方法两则 |
步骤一 1.新建一个同名的数据库 2.再停掉sql server( 留神不要 拆散数据库) 3.用原数据库的数据文件 遮蔽掉这个新建的数据库 4.再重启sql server 5.此时 打开企业治理器时会浮现置疑,先 无论,执行下面的语句( 留神 批改其中的数据库名) 6.
实现后普通就
可以
拜访数据库中的数据了,这时,数据库
本身普通还要问题,解决
步骤是,利用 USE MASTER SP_CONFIGURE 'ALLOW UPDATES',1 RECONFIGURE WITH OVERRIDE UPDATE SYSDATABASES SET STATUS =32768 WHERE NAME='置疑的数据库名' sp_dboption '置疑的数据库名', 'single user', 'true' DBCC CHECKDB('置疑的数据库名') update sysdatabases set status =28 where name='置疑的数据库名' sp_configure 'allow updates', 0 reconfigure with override sp_dboption '置疑的数据库名', 'single user', 'false' 步骤二
事件的起因 这下子坏了!这个数据库连不上了,企业治理器在它的旁边写着“(置疑)” 。并且最要命的,这个数据库 向来没有备份了 。我唯一找得到的是 迁徙半年前的另外一个数据库服务器, 利用倒是能用了,然而少了许多记录、表和存储过程 。真 盼望这只是一场噩梦! 没有
动机的
复原步骤 1,
拆散被置疑的数据库,
可以
使用sp_detach_db 然而,很遗憾,执行之后,SQL Server质疑数据文件和日志文件不符,所以 无奈附加数据库数据文件 。 DTS数据导出 紧急模式 1,把数据库设置为emergency mode 2,再一次 构建一个log文件 3,把SQL Server 再一次启动一下 4,把 利用数据库设置成单消费者模式 5,做DBCC CHECKDB 6,假如没有什么大问题就 可以把数据库状态改回去了,记得别忘了把系统表的 批改选项关掉 我 实际了一下,把 利用数据库的数据文件移走,再一次 构建一个同名的数据库XXX, 而后停掉SQL服务,把原来的数据文件再 遮蔽回来 。之后,依照怡红公子的步骤走 。 然而,也很遗憾,除了第2步之外, 其余步骤执行十分 顺利 。惋惜,重启SQL Server之后,这个 利用数据库 依旧是置疑! 不过,让我 快慰的是,这么做之后,倒是 可以Select数据了,让我大出一口气 。只是,组件 使用数据库时,报告说:“ 产生 舛误:-2147467259,未能在数据库 'XXX' 中运行 BEGIN TRANSACTION,由于该数据库处于回避 复原模式 。” 最终
顺利
复原的所有步骤 执行
后果: 接着运行“update sysdatabases set status = 32768 where name = 'XXX'” 重启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导出向导 复制源 取舍EmergencyMode的数据库XXX,导入到XXX.Lost; 取舍“在SQL Server数据库中间复制对象和数据”,试了 频繁, 如同不行,只是复制过来了所有表 构造,然而没有数据,也没有视图和存储过程,并且DTS向导最终报告复制失败; 所以最终 取舍“从源数据库复制表和视图”,然而后来发现,这样总是不得不复制一 部分表记录; 于是 取舍“用一条 查问指定要传输的数据”,缺哪个表记录,就导哪个; 视图和存储过程是执行SQL语句增加的 。 这样,XXX.Lost数据库就 可以替换原来的 利用数据库了 |