SQL的823错该怎么改?

作者&投稿:侯杜 (若有异议请与网页底部的电邮联系)
SQL Server数据库附加提示“823”错误怎么办~

sqlserver附加数据库错误823的解决方案2008-10-13 15:06sqlserver附加数据库错误823的解决方案一、SQL-Server附加数据库时失败。
1、异常情况:服务器在正常运行的情况下突然断电,导致数据库文件损坏,具体表现是:数据库名后面有“(置疑)”字样。
2、异常分析:关于823错误的 SQL-SERVER 中的帮助:
================================

错误 823
严重级别 24
消息正文
在文件 "%4!" 的偏移量 %3! 处的 %2! 过程中,检测到 I/O 错误 %1!。

解释
Microsoft SQL Server 在对某设备进行读或写请求时遇到 I/O 错误。该错误通常表明磁盘问题。但是,错误日志中在错误 823 之前记录的其它核心消息应指出涉及了哪个设备。
3、解决办法:
在SQL-Server企业管理器中,新建同名数据库(这里假设为Test)后,停止数据库,把损坏的数据库文件Data.mdf和Test_log.LDF覆盖刚才新建数据库目录下的Data.mdf和Test_log.LDF,同时删除Test_log.LDF文件;启动数据库服务,发现数据库名Test后面有“置疑”字样。不要紧,打开SQL自带查询分析器,分别执行如下SQL语句:
第一、
exec sp_configure 'allow updates',1 RECONFIGURE WITH OVERRIDE /* 打开修改系统表的开关 */
第二、
update sysdatabases set status=32768 where name='数据库名' /* 设置数据库状态 */
第三、
DBCC REBUILD_LOG ('数据库名','D:\database\Test_Log.LDF') /* 重建LDF文件 */
第四、
update sysdatabases set status=0 where name='数据库名' /* 重置数据库状态 */
第五、
restore database 数据库名 WITH RECOVERY /* 恢复数据库 */
第六、
exec sp_configure 'allow updates',0 RECONFIGURE WITH OVERRIDE /* 关闭打开修改系统表的开关 */
按照此方法操作,应该能修复数据库正常访问了。如果问题依然存在,最笨的一个方法就是新建另一个数据库,把原数据库(Test)各个表的数据导出到新建数据库表中。
============================================================
补充说明:用上面的六步把数据库置疑的问题解决了,但是数据库表里还有损坏的表(inf_gdscode),把坏表导出的时候也不成功。最后在查询分析器里运行:

USE nmgbt_hcxuexipos (数据库名)
GO
DBCC CHECKTABLE ('inf_gdscode',REPAIR_ALLOW_DATA_LOSS)
GO

823错误,也就是所谓的硬IO错误,可以理解为SQL Server希望读取到某页,而Windows告诉SQL Server,无法读取到该页,这情况一般是SQL Server文件页有缺失所致,通过用WINHEX分析SQL Server文件的结构再用其备份补上这一页就可以了。找正大数据帮恢复,很多年了!特别牛X~~~~

nbsp;最近工作上碰见SQL数据库附加提示“823”号错误。从网上搜了一些资料,按照几个方法执行后解决了此类问题。并对解决后数据库出现不一致的问题也做了解决办法的说明。我的数据库是因为服务器系统坏掉,重新安装到别的服务器上了,把数据库文件和日志拷过去后,想附加,结果出现了823错误提示。于是就到网上百度了一下,找到了这个方法。

原因: 1、因为停电等原因造成MSSQL数据库,提示823错误。

2、日志文件被破坏823错误。

SQL Server数据库备份有两种方式,一种是使用BACKUP DATABASE将数据库文件备份出去,另外一种就是直接拷贝数据库文件mdf和日志文件ldf的方式。下面将主要讨论一下后者的备份与恢复。本文假定您能熟练使用SQL Server Enterprise Manager(SQL Server企业管理器)和SQL Server Quwey Analyser(SQL Server查询分析器)
1、正常的备份、恢复方式
正常方式下,我们要备份一个数据库,首先要先将该数据库从运行的数据服务器中断开,或者停掉整个数据库服务器,然后复制文件。
卸下数据库的命令:Sp_detach_db 数据库名
连接数据库的命令:Sp_attach_db或者sp_attach_single_file_db
s_attach_db [@dbname =] ′dbname′, [@filename1 =] ′filename_n′ [,...16]
sp_attach_single_file_db [@dbname =] ′dbname′, [@physname =] ′physical_name′
使用此方法可以正确恢复SQL Sever7.0和SQL Server 2000的数据库文件,要点是备份的时候一定要将mdf和ldf两个文件都备份下来,mdf文件是数据库数据文件,ldf是数据库日志文件。
例子:
假设数据库为test,其数据文件为test_data.mdf,日志文件为test_log.ldf。下面我们讨论一下如何备份、恢复该数据库。
卸下数据库:sp_detach_db 'test'
连接数据库:sp_attach_db 'test','C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_data.mdf','C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_log.ldf'
sp_attach_single_file_db 'test','C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_data.mdf'
2、只有mdf文件的恢复技术
由于种种原因,我们如果当时仅仅备份了mdf文件,那么恢复起来就是一件很麻烦的事情了。
如果您的mdf文件是当前数据库产生的,那么很侥幸,也许你使用sp_attach_db或者sp_attach_single_file_db可以恢复数据库,但是会出现类似下面的提示信息
设备激活错误。物理文件名 'C:\Program Files\Microsoft SQL Server\MSSQL\data\test_Log.LDF' 可能有误。
已创建名为 'C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_log.LDF' 的新日志文件。
但是,如果您的数据库文件是从其他计算机上复制过来的,那么很不幸,也许上述办法就行不通了。你也许会得到类似下面的错误信息
服务器: 消息 1813,级别 16,状态 2,行 1
未能打开新数据库 'test'。CREATE DATABASE 将终止。
设备激活错误。物理文件名 'd:\test_log.LDF' 可能有误。
怎么办呢?别着急,下面我们举例说明恢复办法。
A我们使用默认方式建立一个供恢复使用的数据库(如test)。可以在SQL Server Enterprise Manager里面建立。
B.停掉数据库服务器。
C.将刚才生成的数据库的日志文件test_log.ldf删除,用要恢复的数据库mdf文件覆盖刚才生成的数据库数据文件test_data.mdf。D.启动数据库服务器。此时会看到数据库test的状态为“置疑”。这时候不能对此数据库进行任何操作。E.设置数据库允许直接操作系统表。此操作可以在SQL Server Enterprise Manager里面选择数据库服务器,按右键,选择“属性”,在“服务器设置”页面中将“允许对系统目录直接修改”一项选中。也可以使用如下语句来实现。
use master
go
sp_configure 'allow updates',1
go
reconfigure with override
go
F.设置test为紧急修复模式
update sysdatabases set status=-32768 where dbid=DB_ID('test')
此时可以在SQL Server Enterprise Manager里面看到该数据库处于“只读\置疑\脱机\紧急模式”可以看到数据库里面的表,但是仅仅有系统表
G.下面执行真正的恢复操作,重建数据库日志文件
dbcc rebuild_log('test','C:\Program Files\Microsoft SQL Server\MSSQL\Data\test_log.ldf')
执行过程中,如果遇到下列提示信息:
服务器: 消息 5030,级别 16,状态 1,行 1
未能排它地锁定数据库以执行该操作。
DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。[brown]
说明您的其他程序正在使用该数据库,如果刚才您在F步骤中使用SQL Server Enterprise Manager打开了test库的系统表,那么退出SQL Server Enterprise Manager就可以了。
正确执行完成的提示应该类似于:
[brown]警告: 数据库 'test' 的日志已重建。已失去事务的一致性。应运行 DBCC CHECKDB 以验证物理一致性。将必须重置数据库选项,并且可能需要删除多余的日志文件。
DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。
此时打开在SQL Server Enterprise Manager里面会看到数据库的状态为“只供DBO使用”。此时可以访问数据库里面的用户表了。
H.验证数据库一致性(可省略)
dbcc checkdb('test')
一般执行结果如下:
CHECKDB 发现了 0 个分配错误和 0 个一致性错误(在数据库 'test' 中)。
DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。
I.设置数据库为正常状态
sp_dboption 'test','dbo use only','false'
如果没有出错,那么恭喜,现在就可以正常的使用恢复后的数据库啦。
J.最后一步,我们要将步骤E中设置的“允许对系统目录直接修改”一项恢复。因为平时直接操作系统表是一件比较危险的事情。当然,我们可以在SQL Server Enterprise Manager里面恢复,也可以使用如下语句完成
sp_configure 'allow updates',0
go
reconfigure with override
go

对于提示"分配错误"及"一致性错误"依次执行下列语句:

sp_dboption '数据库', 'SINGLE USER', TRUE
DBCC CHECKDB('数据库', REPAIR_ALLOW_DATA_LOSS)
sp_dboption '数据库', 'SINGLE USER', FALSE

用这些修复语句修复后,返回的一些有代表性的错误信息:

再根据错误信息,查询不能修复的信息备份,将之删除,再将备份的信息插入原来的地方,问题解决


ug的jt怎么可以编辑?
与其坐等工作机会的到来,不如制定一个半年、一年和五年的计划。“我知道我想在五年内达到某某水平,所以在回顾阶段,我去找我的经理,问他我怎么才能达到这个目标,”管培生James说道,“我意识到自己需要提高公开演讲的水平,这激发了我去参加一个演讲的课程。我觉得从长远考虑可以帮助你意识到要达到目标需要多少步。”11...

我的电脑鼠标左键双击,点出来的是快捷键是怎么会事?
⑤ Ctrl+Z\\Y:撤回\\恢复包括短时间内我们在电脑做了一些操作,比如删除一个文件发现删错了,可以用这种方式撤回操作让文件恢复。同时在软件操作中这个快捷键更加常用。反过来,因为按了次数较多的撤回而出错,可以通过恢复操作直到满意的情况。Shift篇① Shift+Delete:永久删除直接删除会进入回收站,也会占用系统内存。当确...

明白悍马车的朋友来
至于防弹,这更是按客户要求来改了(当然,很多牌子有直接量产的防弹车,我们就讨论悍马),楼主想知道的防弹性能和抗撞击性能,那不同的车数据基本是不同的,没有看到那辆车,也无从下手来分析了。但就悍马这原型车来看,改装后应该能达到很强的级别,一是其“底子”好,经得起防弹的大改,二是,...

察雅县18331678203: SQL的823错该怎么改? -
闻复欧迪: nbsp;最近工作上碰见SQL数据库附加提示“823”号错误.从网上搜了一些资料,按照几个方法执行后解决了此类问题.并对解决后数据库出现不一致的问题也做了解决办法的说明.我的数据库是因为服务器系统坏掉,重新安装到别的服务器...

察雅县18331678203: SQL SERVER数据库报823错误怎么解决? -
闻复欧迪: 823错误,也就是所谓的硬IO错误,可以理解为SQL Server希望读取到某页,而Windows告诉SQL Server,无法读取到该页,这情况一般是SQL Server文件页有缺失所致,通过用WINHEX分析SQL Server文件的结构再用其备份补上这一页就可以了.找正大数据帮恢复,很多年了!特别牛X~~~~

察雅县18331678203: sqlserver 附加数据库 错误823 如何解决? -
闻复欧迪: sqlserver附加数据库错误823的解决方案 一、SQL-Server附加数据库时失败.1、异常情况:服务器在正常运行的情况下突然断电,导致数据库文件损坏,具体表现是:数据库名后面有“(置疑)”字样.2、异常分析:关于823错误的 SQL-...

察雅县18331678203: sql附加823错误”的解决方法 -
闻复欧迪: 在SQL-Server企业管理器中,新建同名数据库(这里假设为Test)后,停止数据库,把损坏的数据库文件Data.mdf和Test_log.LDF覆盖刚才新建数据库目录下的Data.mdf和Test_log.LDF,同时删除Test_log.LDF文件;启动数据库服务,发现数据...

察雅县18331678203: 急急急........sql2000附加数据库出现823错误 -
闻复欧迪: 1.新建一个同名的数据库(数据文件与原来的一致) 2.再停掉sql server 3.用原数据库的数据文件覆盖掉这个新建的数据库 (.mdf和Ldf)都覆盖了 为什么直接覆盖呢?直接导入数据或者附加库不是更好么?

察雅县18331678203: SQL2000 收缩数据库时出现 错误:823 -
闻复欧迪: 这个比较麻烦,1 删除冗余数据 2 对 数据库里的索引进行优化. 优化没有好办法,也不是一两个语句搞定的,要么自己下功夫学习下.要么请别人做吧!现在专门有人做这方面的活.

察雅县18331678203: sql 错误 823
闻复欧迪: 微软说这可能是硬件IO错误或系统错误,你需要联系硬件供应商/系统管理员. http://support.microsoft.com/kb/828339 我觉得最最应该先做的是先把数据文件拷贝出来备份.

察雅县18331678203: SQL server数据库出现824错误怎么解决 -
闻复欧迪: 引用SQLServer帮助的信息:此错误表明 Windows 报告已从磁盘成功读取页,但 SQL Server 检测到页中存在错误.此错误与错误 823 类似,只是 Windows 不检测这一错误.这通常表明 I/O 子系统中存在问题,例如磁盘驱动器存在故障、磁盘...

察雅县18331678203: SQL server 2000 数据库中的表出现823错误要怎么修复求大神门给解下...
闻复欧迪: 可以处理.

察雅县18331678203: Sql Server 数据库启动报这种错误怎么办 -
闻复欧迪: 1.开始-->管理管理工具-->服务 2.启动SQL Server(MSSQLSERVER ) 或者 1.打开SQL Server 2005中的配置工具SQL Server Configure Manager,将VIA协议禁用 2.重新启动SQL Server(MSSQLSERVER ) 或者 重新安装

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网