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

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. elimination-game

    https://leetcode.com/problems/elimination-game/ // 一行代码就可以,不过原理有些复杂 // https://discuss.leetcode.com/ ...

  2. 网站日志访问记录组件UserVisitLogsHelp开源了!

    之前在<一种基于自定义代码记录用户访问日志在Sharepoint网站的应用方法!>一文利用本人几年前的开发的UserVisitLogsHelp组件进行了网站用户访问日志记录,可用于网站分析 ...

  3. atoi(),atof等函数的实现

    atoi()函数的功能:将字符串转换成整型数:atoi()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负号才开始做转换,而再遇到非数字或字符串时('\0')才结束转化,并将结果返回( ...

  4. 【Handler】Looper 原理 详解 示例 总结

    核心知识点 1.相关名词 UI线程:就是我们的主线程,系统在创建UI线程的时候会初始化一个Looper对象,同时也会创建一个与其关联的MessageQueue Handler:作用就是发送与处理信息, ...

  5. 网络结构设计——负载均衡之LVS学习笔记(四)

    LVS按个人理解的说就是将一台Linux服务器当作路由器等功能的技术.LVS---Linux虚拟服务器. LVS实现了三种IP负载均衡技术VS/NAT.VS/TUN.VS/DR. 今天简单分享一下我在 ...

  6. (转)Unity3D占用内存太大的解决方法

    自:http://www.cnblogs.com/88999660/archive/2013/03/15/2961663.html 最近网友通过网站搜索Unity3D在手机及其他平台下占用内存太大.  ...

  7. java list按照元素对象的指定多个字段属性进行排序

    ListUtils.java---功能类 package com.enable.common.utils; import java.lang.reflect.Field;import java.tex ...

  8. Java的泛型中,通配符可以设置上限和下限

    上限:<? extends T> ?是T和T的子类 下限:<? super T> ?是T和T的父类 怎么看待这个上限和下限呢 首先应该想 其实对于Java来说 <? ex ...

  9. [Android] Content provider, ContentResolver

    Content provider的作用: Content providers manage access to a structured set of data. They encapsulate t ...

  10. 12款程序员们最爱的Bootstrap模板

    如果你还没有开始使用Bootstrap模板,那你可真是有够OUT,这是一个帮助你快速开发的工具,Bootstrap是基于jQuery框架开发的,它在jQuery框架的基础上进行了更为个性化和人性化的完 ...