什么人跟菩萨有缘:VFP文件遭损坏,简单修复

来源:百度文库 编辑:中财网 时间:2024/04/29 14:01:29
A:如何修复被破坏的VFP表(*.dbf) 

----目前在我国,有相当一部分正在运行应用程序是用VFP   编写的,由于突然断电、程序非法关闭等原因,经常会导致VFP数据库.DBF文件被破坏,如果数据库被破坏了,用VFP打开数据库.DBF时,会出现 "notatable/dbf "错误提示,导致无法用VFP打开。 
----首先介绍一下VFP数据库.DBF的文件结构: 
----VFP数据库*.DBF的文件结构由头记录和数据记录组成,头记录定义该DBF的结构并包含与该库相关的其它信息。头记录由文件位置0字节开始。 
----数据库头部几个关键字节含义如下:(注:库文件中存储整数时低位字节在前) 
----字节偏移说明 
----0   库文件的版本类型 
----1-3   最近更新的日期(YYMMDD) 
----4-7   库文件中记录的个数 
----8-9   第一条记录的起始位置 
----10-11   一条记录的长度(包括删除标记) 
----其它字节的具体描述不在此赘述,可以参考有关部门书籍或者程序开头注释部分。 
----在实际工作中发现,许多情况下数据库错误都是由于记录个数比实际记录个数大1个,以至于数据库无法用打开。 
----主要通过以下两种办法来对数据库进行修复。 

一、用Pctools、NU的Diskedit等工具软件进行恢复: 

----运行Pctools,选中无法打开的数据库,按E文件进入编辑功能,按F1切换显示模式。 
----按F3进行编辑,将开始的第5个字节值减1,按F5存储,然后退出Pctools,启动VFP,   发现被破坏的数据库可以打开使用了。 
----由于许多操作者并不一定熟悉如何使用Pctools,因此我建议大家可以用比较熟悉的Excel程序根据下面的步骤来进行数据库的恢复。 

二、用Excel进行恢复。 

----启动Excel,选择 "打开 "按钮,出现打开对话框,在打开文件类型中选择Dbase/VFP(*.DBF)文件类型,再选中被破坏的数据库打开,这时不要做更改,只选择 "保存 "按钮,会出现 "另存为 "对话框,仍选择以原来文件名保存,会提示 "文件已经存在,是否替换已有文件? ",选择 "是 "。 
----然后选择 "文件 "菜单上的 "关闭 ",会出现提示 "数据库文件不是Excel格式,要保留修改吗? 
----要保存为Excel格式,单击 '是 ',然后在 '保存类型 '下拉列表框选 'Excel工作簿 '; 
----要用现有格式保存并替换原来的文件,单击 '是 ',然后单击 '保存 '; 
----要在关闭文件时维持现有格式并不作保存,单击 '否 '。 " 
----由于我们并没有对数据库的记录进行改动,只是为了恢复数据库,所以选择最后一项 "在关闭文件时维持现有格式并不作保存 ",因此单击 "否 ",退出Excel。 
----启动VFP,再次打开数据库文件,发现数据库文件已可以被打开了,但是观察数据库的结构,会发现数据库结构中的索引不见了,不过数据库的索引文件还存在。我们只需要给数据库Add索引,并选择原来的索引文件Open即可。 
----添加索引文件后退出数据库结构设置,并对数据库重新索引一下,就可以继续使用原   来被破坏的数据库了。 

三、如果是VFP6的DBF,那么用VFP8打开试一试。如果是VFP8的DBF,那么用VFP6打开试一试