盆盆罐罐

上海邦麦信息科技有限公司旗下子网站;POS系统、计算机技术资料搜集

SQL中附加数据库的时候出现错误9003的解决

SQL 2000,附加数据库的时候出现错误提示:“错误9003:LSN(39:431:1)无效,该LSN是传递给数据库’XXX’中的日志扫描操作的”,如图:

9003

出现这个错误一般是因为此数据库有损坏,导致不能做数据库的附件操作。

解决步骤:

  1. 停止SQL Server服务器,将旧数据库文件和相应的日志文件拷贝到其他地方以备份
  2. 启动SQL Server服务器,新建一个全新的和旧数据库同名的数据库
  3. 停止SQL Server服务器,将旧数据库的mdf和ldf文件覆盖新的mdf和ldf文件
  4. 再启动SQL Server服务器,这个时候数据库应该处于置疑状态
  5. 查询分析器中执行以下语句:
    use master
    go
    
    sp_configure 'allow updates', 1
    reconfigure with override
    go
    
    update sysdatabases set status= 32768 where name = '数据库名'
  6. 再执行如下语句:
    dbcc rebuild_log('数据库名', '新的ldf文件的绝对路径'). -- 你会看到一个消息 - Warning: The log for database '数据库名' has been rebuilt.(注意,这里的 '新的ldf文件的绝对路径'是一个不存在的文件,待会它会自己建立)
    
    use master
    go
    
    sp_configure 'allow updates', 0
    go
  7. 既然数据库有损坏,我们就还需要检查错误和修复错误,具体方法见此文:检测和修复SQL数据库错误

参考资料:

  1. http://bbs.csdn.net/topics/260083404
  2. http://www.wangchao.net.cn/bbsdetail_1785769.html

分类:数据库

标签:, , ,

对本文发表评论





2 + 4 = ?

注意:
1、请勿单纯发表顶啊、打酱油之类无任何意义的评论,否则将被视为spam!谢谢合作!
2、但欢迎你留下对本文的看法或技术上的任何疑问,我会及时回复你。