如何修复被破坏的Foxpro数据库

 

随着统计事业的不断发展和电子计算机技术的广泛应用, 大量统计数据加工整理工作已摆脱了传统的手工操作, 迈上了数据处理现代化的轨道。Foxpro关系型数据库管理系统的广泛运用给我们处理统计数据带来了更多方便。因为数据库管理系统具有建库简单、操作容易、适应性强等优点, 其数据还可以与其它高级语言共享, 如BASIC、C、 FORTRAN等。然而由于突然断电、程序非法关闭等原因,经常会导致Foxpro数据库.DBF文件被破坏,如果数据库被破坏了,用Foxpro打开数据库.DBF时,会出现"notatable/dbf"错误提示,导致无法用Foxpro打开。

Foxpro数据库.DBF的文件结构:

Foxpro数据库*.DBF的文件结构由头记录和数据记录组成,头记录定义该DBF的结构并包含与该库相关的其它信息。头记录由文件位置0字节开始。

数据库头部几个关键字节含义如下:

字节偏移说明:

0     库文件的版本类型

1-3   最近更新的日期(YYMMDD)

4-7   库文件中记录的个数

8-9   第一条记录的起始位置

10-11 一条记录的长度(包括删除标记)

在实际工作中发现,许多情况下数据库错误都是由于记录个数比实际记录个数大1个,以至于数据库无法打开。

以上情况可通过如下两种办法来对数据库进行修复。

一、用Pctools工具软件进行恢复:

运行Pctools,选中无法打开的数据库,按E文件进入编辑功能,按F1切换显示模式。

F3进行编辑,将开始的第5个字节值减1,按F5存储,然后退出Pctools,启动Foxpro,这是被破坏的数据库可以打开使用了。

利用Pctools修复数据库的另一种方法是:进入Pctools后,选中原备份的能打开的数据库,进入编辑,将有关数据记录下来,退出后,再选中无法打开的数据库,进入编辑,与记录下来的数据进行比较,若有不同按照记录下来的数据改过来即可。

二、用Excel97进行恢复。

启动Excel97,选择打开按钮,出现打开对话框,在打开文件类型中选择Dbase/Foxpro(*.DBF)文件类型,再选中被破坏的数据库打开。

这时不要做更改,只选择“保存”按钮,会出现“另存为”对话框,仍选择以原来文件名保存,会提示“文件已经存在,是否替换已有文件?”,选择“是”。

    然后选择“文件”菜单上的“关闭”,会出现如下提示:

    “数据库文件不是Excel格式,要保留修改吗?

要保存为Excel格式,单击,然后在保存类型下拉列表框选Excel工作簿

要用现有格式保存并替换原来的文件,单击‘是’,然后单击‘保存’;

要在关闭文件时维持现有格式并不作保存,单击‘否’。”

由于我们并没有对数据库的记录进行改动,只是为了恢复数据库,所以选择最后一项“在关闭文件时维持现有格式并不作保存”,因此单击“否”,退出Excel。

启动Foxpro,再次打开数据库文件,发现数据库文件已可以被打开了,但是观察数据库的结构,会发现数据库结构中的索引不见了,不过数据库的索引文件还存在。我们只需要给数据库Add索引,并选择原来的索引文件Open即可。

添加索引文件后退出数据库结构设置,并对数据库重新索引一下,就可以继续使用原来被破坏的数据库了。