MSSQL

sql server系统表损坏的解决方法

日期:2021/9/9 1:02:36来源: IT猫扑网

如果sql server系统表损坏了,应该怎么办呢?下面就教您一个sql server系统表损坏的解决方法,供您参考,希望对您能够有所帮助。

sql server系统表损坏的解决方法

一、sql server数据库中三张重要的sql server系统表

sysobjects:在数据库内创建的每个对象(约束、默认值、日志、规则、存储过程等)在表中占一行。

sysindexes:数据库中的每个索引和表在表中各占一行。

syscolumns:每个表和视图中的每列在表中占一行,存储过程中的每个参数在表中也占一行。

这三张表用ID(表ID)字段关联。这三张系统表一旦损坏,与之对应数据库对象将无法访问,其作用相当于DOS中的"文件分配表" 。

二、sql server系统表损坏的症状

用 DBCC CHECKDB 携带任何参数都无法修复数据库,也就是说:DBCC CHECKDB对这个帐套根本不起作用;

无法执行如下操作:

select * from sysobjects 或select * from sysindexes 或select * from syscolumns ;

无法用SQL server DTS或其他SQL 脚本导库工具进行导库,导库的中途失败,报告:连接中断;

在企业管理器或查询分析器中,部分用户数据表无法访问。

三、处理方法

处理这种数据库,分为两个大的步骤:

第一步:处理可以访问的数据表

1)找出哪些表不可访问,即:sql server系统表中哪些记录损坏;

2)用SQL server DTS把能够访问的用户数据表导入一个新的DataBase 。

在导库时,不能选折(1)中不能访问的数据表。

第二步:处理不可访问的数据表:

1)找出系统表中错误记录的ID;

2)根据"错误记录的ID",删除sysobjects、sysindexes、syscolumns 表错误的记录;

3)根据"错误记录的ID" ,重建系统表记录;

4)重建完毕,如果该表可以访问,那么用DTS单独将此表导入新的DataBase。

说明:重建sql server系统表方式不一定会成功,比如由于DISK I/O错误,如果仅仅是保存系统表的磁盘扇区出错,那么重建系统表方式可以挽回数据。 如果保存用户数据表的磁盘扇区出错,那么即使重建系统表也不能解决问题。如果重要的用户数据表无法导库,如:t_Voucher、 IcStockbill、ICSale等,那么可以用用"第二步"中的方法一试。

相关文章

相关下载

网友评论

我要评论...
    没有更早的评论了
    取消