我的SQL数据库在写入数据的时候突然停电了,再打开电脑就出现了数据库质疑,应该怎么解决

我的SQL数据库在写入数据的时候突然停电了,再打开电脑就出现了数据库质疑,应该怎么解决,第1张

修复断电等损坏的SQL 数据,你可以试试。

数据库名为:FreeHost

首先是设置为单用户模式,然后修复,最后是恢复多用户模式。

ALTER DATABASE [FreeHost] SET SINGLE_USER

GO

DBCC CHECKDB('FreeHost',repair_allow_data_loss) WITH TABLOCK

GO

ALTER DATABASE [FreeHost] SET MULTI_USER

GO

注:

--CHECKDB 有3个参数:

--REPAIR_ALLOW_DATA_LOSS

-- 执行由 REPAIR_REBUILD 完成的所有修复,包括对行和页进行分配和取消分配以改正分配错误、结构行或页的错误,以及删除已损坏的文本对象。这些修复可能会导致一些数据丢失。修复 *** 作可以在用户事务下完成以允许用户回滚所做的更改。如果回滚修复,则数据库仍会含有错误,应该从备份进行恢复。如果由于所提供修复等级的缘故遗漏某个错误的修复,则将遗漏任何取决于该修复的修复。修复完成后,备份数据库。

--REPAIR_FAST 进行小的、不耗时的修复 *** 作,如修复非聚集索引中的附加键。这些修复可以很快完成,并且不会有丢失数据的危险。

--REPAIR_REBUILD 执行由 REPAIR_FAST 完成的所有修复,包括需要较长时间的修复(如重建索引)。执行这些修复时不会有丢失数据的危险。

--DBCC CHECKDB('FreeHost') with NO_INFOMSGS,PHYSICAL_ONLY

先使用“无日志附加”的方法进行附加数据后,对数据库做DBCC检测,然后针对错误进行修复 。一般如果数据库正在进行读写 *** 作,突然断电,会导致数据库无法回写正常的数据,这样就会导致数据库索引及其它错误,常见的有“并闫锁页错误”、“表错误: 分配单元ID 169144,页(1:XXXX)。测试(IS_OFF (BUF_IOERR, pBUF->bstat))失败。”,可以先用DBCC先进行修复 ,命令:

DBCC CHECKDB(DBName,REPAIR_FAST) --不丢失数据

DBCC CHECKDB(DBName,REPAIR_REBUILD)--不丢失数据

DBCC CHECKDB(DBName,REPAIR_ALLOW_DATA_LOSS)--会丢失数据

如果还是修复不好,就找专业的数据恢复公司做修复吧,可以找北亚数据恢复修复 ,他们修复SQL数据库很厉害。。。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10037902.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存