数据库置疑之后修复完,用 dbcc checkdb(数据库名) 检查数据的时候提示有一致性错误

CHECKDB 发现了 0 个分配错误和 14 个一致性错误(在数据库 '数据库名' 中)。
repair_allow_data_loss 是最低的修复级别(对于由 DBCC CHECKDB (数据库名 ) 发现的错误而言)。
DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

这个问题是怎么处理?

数据库置疑之后修复完,用 dbcc checkdb(数据库名) 检查数据的时候提示有一致性错误是设置错造成的,解决方法为:

1、使用 phpMyAdmin 自带的修复表,选中需要修复的表,然后点击修复表。

2、使用Navicat for MySQL修复打开数据库之后选择需要修复的表按右键 修复。

3、使用cmd修复,首先定位到数据库安装目录。

4、然后登录数据库。

5、然后repair table 需要修复的表就行了。

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2017-09-18
数据库 CHECKDB 发现了x个分配错误和 x 个一致性错误
现在以数据库text为例,说明该问题的处理方法:
--1、在SQL查询分析器中执行以下语句:(注以下所用的text为数据库名称,请用户手工改为自己的数据库名)

use text
dbcc checkdb

--2、查看查询结果,有很多红色字体显示,最后结果有这样的提示:
--CHECKDB --发现了x个分配错误和 x 个一致性错误(在数据库 'text' 中)。
--一般情况下,引起分配错误的原因是磁盘损坏或突然停电;一致性错误可能是数据库中的表或索引坏,一般都可修复。
--3、查看红色字体,并把有错误的数据库表名记录下来,或把索引损坏的表名记录下来。
--4、把数据库设置为单用户模式,直接在查询分析器中执行以下语句即可:(如发现语句运行不成功,请把用户的电脑注销一下,后再重新运行一下。)

EXEC sp_dboption 'text, 'single user', 'TRUE'

--5、进入查询分析器执行如下语句:

use text
dbcc checkdb('text',repair_allow_data_loss) -------修复数据库

dbcc checkdb ('text',REPAIR_REBUILD) -------修复数据库索引

--6、再执行:dbcc checkdb,检测数据库,出现结果为:

--CHECKDB 发现了0个分配错误和 0个一致性错误(在数据库 'text' 中)。

--数据库已经修复完毕。
--7、取消单用户模式,即直接在查询分析器中执行以下语句即可:

EXEC sp_dboption 'pos', 'single user','FALSE'

参考资料:http://www.mugua.net/post/61.html

本回答被提问者采纳
相似回答