SqlServer2000
1. 非正常删除log数据文件恢复过程 由于空间不足数据库备份无法执行,分离数据库,删除数据库事物日志,无法附加数据库,提示设备激活错误。 使用returndate.mdf数据库文件恢复数据库: Ø 建立一个数据库returndate,停止数据库服务。 Ø 将创建数据库后生成的数据库的日志文件returndate_log.ldf删除,用要恢复的数据库mdf文件覆盖刚才生成的数据库数据文件returndate_data.mdf。 启动数据库服务。此时会看到数据库returndate的状态为“置疑”。这时候不能对此数据库进行任何操作。如图:
Ø 设置数据库允许直接操作系统表。 use master go sp_configure 'allow updates',1 go reconfigure with override go Ø 设置returndate为紧急修复模式,如图:
update sysdatabases set status=-32768 wheredbid=DB_ID('returndate') Ø 下面执行真正的恢复操作,重建数据库日志文件 Dbcc rebuild_log ('returndate','D:\ProgramFiles\MicrosoftSQL Server\MSSQL\Data\returndate_log.ldf') 提示警告: 数据库 'test' 的日志已重建。已失去事务的一致性。应运行 DBCC CHECKDB 以验证物理一致性。将必须重置数据库选项,并且可能需要删除多余的日志文件。 Ø 验证数据库一致性 dbcc checkdb('returndate') 如图:
Ø 设置数据库为正常状态 sp_dboption 'returndate','dbo useonly','false' 没有出错。 Ø 数据库允许直接操作系统表设置恢复, use master go sp_configure 'allow updates',0 go reconfigure with override go 如图:
Ø 恢复成功.如图:
Ø 由于数据日志文件产生巨大和数据库设置有关,在数据属性-故障还原:模型由完全修改为简单,设置项里勾选上残缺页检测,自动收缩。如图:
数据库维护,注意定期备份,关注存储数据空间变化