SQL数据库文件损坏,怎么修复

SQL数据库文件损坏,怎么修复,第1张

可以修复,从故障解析,数据库损坏分为逻辑层损坏和物理层损坏。

1,逻辑损坏是指,文件本身完整,系统表在逻辑结构上混乱造成的错误。

2,物理损坏是指,文件由于不完整,导致置疑等故障

数据库损坏,由断电,非法关机,系统重启,文件被误删除,误ghost自己恢复出来的文件附加失败,阵列崩溃等原因造成的。

逻辑层修复方法,网上有很多dbcc修复命令,可以区尝试下、

物理层还是找专业人员吧!

步骤如下:

停止SQL服务管理器,将原数据文件拷贝进行备份,然后将原数据库删除;启动SQLServer服务,创建一个新的数据库,命名为原来数据库的名字;停止SQLServer服务,用备份出来的老数据库的MDF文件替换新数据库相应的MDF文件,并把新数据库相应的LDF文件删除;重新启动SQLServer服务,然后运行命令;停止SQL然后重新启动SQLServer服务,然后运行命令;运行hbfsv8检查数据库的完整性;进行数据库修复;修复成功后,返回多用户模式。

修复sql2000数据库置疑

在实际的 *** 作中由于突然断电或者突然断网造成数据库置疑(在企业管理器中数据库后面出现置疑两个字),下面我们通过以下方法来进行修复置疑的数据库。

A.我们使用默认方式建立一个供恢复使用的数据库(如test)。可以在SQL Server Enterprise Manager里面建立。

B停掉数据库服务器。

C 将刚才生成的数据库的日志文件test_logldf删除,用要恢复的数据库mdf文件覆盖刚才生成的数据库数据文件test_datamdf。

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_logldf')

执行过程中,如果遇到下列提示信息:

服务器: 消息 5030,级别 16,状态 1,行 1

未能排它地锁定数据库以执行该 *** 作。

DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

说明您的其他程序正在使用该数据库,如果刚才您在F步骤中使用SQL Server Enterprise Manager打开了test库的系统表,那么退出SQL Server Enterprise Manager就可以了。

正确执行完成的提示应该类似于:

警告: 数据库 '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

方耀是中国***的优秀党员和革命家,曾经在中国革命中做出了杰出的贡献。他于1946年在内蒙古抗日根据地牺牲,其遗体一度下落不明。直到2012年,他的遗骸被发现,并在2013年经过DNA比对确认身份。

方耀的遗体最终被安葬在了北京市八宝山革命公墓。这是一个充满革命历史和纪念意义的墓园,许多中国革命的先烈和领袖都安葬在这里。八宝山革命公墓具有极高的纪念和历史价值,成为了中国革命文化的重要组成部分。因此,方耀被安葬在这里也是为了彰显他在中国革命中的重要地位,并将其纳入中国革命历史的纪念体系中。

总之,方耀被安葬在北京市八宝山革命公墓,是为了表彰他在中国革命中的贡献,将其纳入中国革命历史的纪念体系中,并让他的精神永存于人们心中。

用户的配置文件就是以前使用电脑的习惯,没有也不要紧,至少多系统来说没危害,你在建立新用户名就好。还有一点要提醒,如果你以前的用户名是加了开机密码的,那你的电脑系统或许已经被人用NET USER方式强行进入过了,这样进入后你的用户名就会不存在了,所以导致你说的这个问题。

注册表(Registry,繁体中文版Windows *** 作系统称之为登录档)是Microsoft Windows中的一个重要的数据库,用于存储系统和应用程序的设置信息。

早在Windows 30推出OLE技术的时候,注册表就已经出现。随后推出的Windows NT是第一个从系统级别广泛使用注册表的 *** 作系统。但是,从Microsoft Windows 95 *** 作系统开始,注册表才真正成为Windows用户经常接触的内容,并在其后的 *** 作系统中继续沿用至今。

以上就是关于SQL数据库文件损坏,怎么修复全部的内容,包括:SQL数据库文件损坏,怎么修复、如何修复SQL数据库置疑、如何修复 SQL 数据库置疑等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: https://outofmemory.cn/sjk/10158483.html

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

发表评论

登录后才能评论

评论列表(0条)

保存