我在工作中时常遇到客户sqlserver2000数据库置疑,网上也有解决办法,自己只是将它整理出来,写得详细一些,方便自己日后查阅。也方便他人查阅。
以下便是详细的步骤:
1.找到备份出来的.mdf。
2.在企业管理器里新建一个同样名字的数据库。
注意:我们软件创建的数据库名称为:abc.mdf,在企业管理器里创建的名字会默认为:abc_data.mdf,
在企业管理器里创建时一定要把_data去掉,不然不会成功,要报错。
3.用原来文件.mdf替换新建的数据库文件,log文件不要(这一步不要停掉服务器)。停掉sql服务器,然后把新 建的.log 文件删除掉。
4.启动数据库,并在企业管理器的数据库服务器上点右键找到属性,把其中服务器设置中允许对系统目录直接进行修改选中.
5.把数据库改成紧急模式,查询分析器中执行:
sp_configure 'allow', 1
reconfigure with override
update sysdatabases set status = 32768 where name = '数据库名'
6.重建log文件:
DBCC REBUILD_LOG ('数据库名', 'D:/TeenySoft/TSMed/Data/数据库名_Log.LDF' )
其中 E:/fdzz/database/fdzz1204_Log.LDF 为日志文件路径。
7.恢复数据库紧急模式
update sysdatabases set status = 0 where name = '数据库名'
8.把服务器设置中允许对系统目录直接进行修改取消。至此已完成。
9.然后用 DBCC CHECKDB ('数据库名')看看有没有错误
DBCC CHECKDB ('数据库名')