如何在SQL Server 2005中修复损坏的数据库

如何在SQL Server 2005中修复损坏的数据库,第1张

1. 在SQL Server Management Studio中随便创建一个数据库,例如:PVLink。

2. 停止SQL Server服务。

如果不停止此服务,刚才创建的PVLink数据库将即不能被拷贝,也不能被覆盖。

3. 把已经损坏的数据库的mdf文件拷贝并覆盖刚才新建的数据库产生的mdf文件。

4. 启动SQL Server服务。

此时可以看见刚才创建的PVLink数据库名字后面没有加号,无法察看其任何信息,其实目前它已经处于无法使用的状态。

5. 把数据库设置为紧急状态

通过在“查询分析器”中执行:alter database PVLink set EMERGENCY 可以将数据库设置为紧急状态,此时数据库PVLink的图标改变成粉红色并出现“紧急”字样。

6. 将数据库设置为单用户模式。

如果不设置为单用户模式,我们将无法使用带有效repair选项的DBCC CHECKDB来检查/修复数据库,SQL Server 2005设置单用户模式比SQL Server 2000容易,只要在“查询分析器”中执行:

use master

go

sp_dboption 'PVLink',single,true

即可。

7. 修复数据库

修复数据库主要使用DBCC来 *** 作,一般来讲,我们可以使用以下三个选项来修复:

REPAIR_ALLOW_ DATA_LOSS

尝试修复报告的所有错误。这些修复可能会导致一些数据丢失。

REPAIR_FAST

仅为保持向后兼容性而保留。

REPAIR_REBUILD

执行由 REPAIR_FAST 执行的所有修复,包括需要较长时间的修复(如重建索引)。执行这些修复时不会有丢失数据的危险。

一般我们通过执行:DBCC CHECKDB('PVLink',REPAIR_REBUILD) 即可完成修复工作,此时 SQL Server 2005会给出很多提示,因为这个过程可能会导致一些数据库设计或者数据的丢失,并且在这个过程中,会产生新的以ldf为扩展名的数据库日志文件。

8. 完成以上的步骤后,一般情况下数据库应该可用了,如果数据库此时仍然是紧急状态,可以通过:alter database PVLink set ONLINE ,把数据库变成在线状态。

EMERGENCY 主要用于故障排除。例如,可以将由于损坏了日志文件而标记为可疑的数据库设置为 EMERGENCY 状态。这样,系统管理员便可对数据库进行只读访问。只有 sysadmin 固定服务器角色的成员才可以将数据库设置为 EMERGENCY 状态。

应该是前面有一次安装失备造成的。

把注册表中搜索SQL Server,所有搜到的项删除,再安装。

注意 *** 作前先备份一下注册表。

或者,系统还原到早期的状态再安装。

步骤

1.先建一个与你要恢复的数据库名称一样的数据库。

2.停止sql server,把你的数据库替换这个数据库。

3.重启sql server,把数据库设置为紧急状态。

sp_configure 'allow',1

reconfigure with overirde

update sysdatabases set status=32768 where name='yourdata'

4.重建日志文件。

dbcc rebuild_log('yourdata','your data path\newdata_log.ldf')

5.取消紧急模式。

update sysdatabases set status=0 where name='yourdata'

restore sysdatabases yourdata with recovery

sp_configure 'allow',0

reconfigure with override

6.重起sql server


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9886887.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存