今天一个数据库损坏了,不管对 该表 查询、修改、添加 都会出错, 错误信息如下:

I/O error (bad page ID) detected during read at offset 0x0000000171a000 in file “路径\文件”
    连接中断

导致错误的可能性有:
     1:服务器在正常运行的情况下突然断电,导致数据库文件损坏。
     2:对某设备进行读或写请求时遇到 I/O 错误。该错误通常表明磁盘问题。
 但对于以上问题都是无法避免的,庆幸的时,网上找到了解决方法(如下)

当出现这个问题的时候,可能有2种情况:
    1 :附加数据库时,提示 错误:823 
     2:能成功附加数据库,但查询、修改 某个指定表时,出现  I/O error (bad page ID) detected during 错误。
 
解决方法:
     第一个 附加数据库问题,可以参考:http://blog.csdn.net/shazhuyubaichi/article/details/6696031

第二个问题:

  1. sp_dboption '数据库名','single user','true'
  2. Go
  3. DBCC CHECKDB('数据库名', REPAIR_ALLOW_DATA_LOSS)
  4. Go
  5. sp_dboption '数据库名', 'single user','false'
  6. Go

我比较庆幸,通过以上语句就可以修复了。
以下是网上的一段摘要,我没有测试,先记录下来,以后或许有用。

    1. 方案1:调用DBCC   CHECKDB(‘db_name’,repair_rebuild)修复
    2. 方案2:若方案1失败,采用下面的方法试一试:
    3. 首先,在企业管理器中新建一数据库(如数据库名为test),建好数据库后,停止SQL Server Service Manager,
    4. 并将客户数据库的MDF文件更名为test_data.mdf(即新建数据库的主文件名),
    5. 然后用更名后的文件覆盖新建数据库同名文件,
    6. 接着,启动企业管理器。对Master数据库将系统表设置为可更改状态
    7. Use   Master
    8. Go
    9. sp_configure 'allow updates ', 1
    10. reconfigure with override
    11. Go
    12. 将数据库设为紧急状态:
    13. update sysdatabases set status = 32768 where name = 'database'
    14. 停止并重新启动SQL Server Service Manager,并重建Log文件:
    15. DBCC TRACEON   (3604)
    16. DBCC REBUILD_LOG( 'test', 'test_log_ldf ')
    17. 将数据库设置为单用户模式,然后进行检测:
    18. sp_dboption  'test', 'single user ', 'true'
    19. DBCC   CHECKDB( 'test')
    20. Go
    21. 此数据库执行CHECKDB的过程中发现一些表的索引被破坏,于是针对具体的表进行重建索引的操作:
    22. DBCC   DBREINDEX(表名)
    23. 方案3:若无法修复,则只能重备份中进行恢复.

SQL 错误 823 I/O error (bad page ID) detected during read【修复方法】的更多相关文章

  1. SQL Server 823,824 错误

    第一: 823错误只代表.SQL server 要向操作系统申请一个页面读写的时候遇到Windos读取或写入失败.823错误是读写请求时发生的 和读写的内容没有关系.823与SQL server 本身 ...

  2. Chrome A标签的迁移错误:【Error loading page】

    在IE中经常使用A标签用来迁移,正确的写法是 <a href="001.html"></a>即可,不过在chrome上面可能会引发错误无法迁移. 比如用下面 ...

  3. Dedecms自定义sql 出现错误Safe Alert: Request Error step 2!

    Dedecms自定义执行sql: SELECT body FROM dede_addonarticle WHERE aid = (select max(aid) fromdede_addonartic ...

  4. 使用 JQueryMobile 点击超链接提示“error loading page” 错误

    使用jquery mobile创建dialog时出现加载错误,“Error Loading Page”. 原因是:jquery mobile页面默认采用ajax方式进行交互,而ajax方式下是不支持f ...

  5. RESTORE detected an error on page (0:0) in database

    在测试服务器还原生产服务器的一个数据库时遇到了下面错误: System.Data.SqlClient.SqlError: RESTORE detected an error on page (0:0) ...

  6. MSSQL 2000 错误823恢复

    一.故障描述 MSSQL Server 2000 附加数据库错误823,附加数据库失败.数据库没有备份,不能通过备份恢复数据库,急需恢复数据库中的数据. 二.故障分析SQL Server数据库 823 ...

  7. MSSQL 2000 错误823恢复案例

    一.故障描述 MSSQL Server 2000 附加数据库错误823,附加数据库失败.数据库没有备份,不能通过备份恢复数据库,急需恢复数据库中的数据. 二.故障分析SQL Server数据库 823 ...

  8. 数据恢复案例分享:MSSQL 2000 错误823

    一.故障描述 MSSQL Server 2000 附加数据库错误823,附加数据库失败.数据库没有备份,不能通过备份恢复数据库,急需恢复数据库中的数据. 二.故障分析SQL Server数据库 823 ...

  9. syntax error, error in :'e id=1?', expect QUES, actual QUES pos 66, line 1, column 66, token QUES错误

    在查询数据库的时候报了下面的异常: syntax error, error in :'e id=1?', expect QUES, actual QUES pos 66, line 1, column ...

随机推荐

  1. WampServer和phpStorm的用法

    WampServer的安装 修改默认的浏览器和文本编辑器 phpStore创建一个PHP工程 在phpStore中运行我们的项目 配制一个PHP Script运行环境 配制一个PHP Web Page ...

  2. Flatten Binary Tree to Linked List leetcode java

    题目: Given a binary tree, flatten it to a linked list in-place. For example, Given 1 / \ 2 5 / \ \ 3 ...

  3. C++11 lambda 表达式解析

    C++11 新增了很多特性,lambda 表达式是其中之一,如果你想了解的 C++11 完整特性,建议去这里,这里,这里,还有这里看看.本文作为 5 月的最后一篇博客,将介绍 C++11 的 lamb ...

  4. Spring Mongo配置多个Mongos

    由于数据存储使用MongoDB集群,在对外访问的时候,地址是Mongos的地址,在使用的过程中没有发现任何问题,配置如下: <mongo:mongo host="${mongodb.h ...

  5. Android动态设置字体颜色

    步骤: 1.在values目录下的strings.xml文件中加入颜色:比方 <color name="ccc">#ccc</color> 2.假设你直接这 ...

  6. solr安装使用笔记

    下载 solr官方下载地址:http://lucene.apache.org/solr/ 使用 启动 solr dir/bin/solr.cmd start 停止 solr dir/bin/solr. ...

  7. ZH奶酪:C语言中malloc()和free()函数解析

    1.malloc()和free()的基本介绍 (1)函数原型及说明 void *malloc(long NumBytes) 该函数分配了NumBytes个字节,并返回了指向这块内存的指针.如果分配失败 ...

  8. Makefile整理

    Makefile里的subst 用法是$(subst FROM,TO,TEXT),即将TEXT中的东西从FROM变为TO Makefile中的字符串处理函数 格式: $(subst <from& ...

  9. 栈的应用实例——平衡符号

    检查().[].{}是否配对. /* stack_balance_symbol */ #include "stack.h" #include <stdio.h> #in ...

  10. ipa 打包遇到的坑

    1.xcode 打包 并上传至 appstore 审核 2.预留邮箱 收取 appstore 的审核结果 3.审核通过以后,通过 iTunes Connect 上传正式文件至 appstore     ...