首先介绍一下Foxpro数据库.DBF的文件结构:
Foxpro数据库*.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,启动Foxpro, 发现被破坏的数据库可以打开使用了握孝。
由于许多 *** 作者并不一定熟悉如何使用Pctools,因此我建议大家可以用比较熟悉的Excel程序根据下面的步骤来进行数据库的恢复。
二、用Excel进行恢复。
启动Excel,选择"打开"按钮,出现打开对话框,在打开文件类型中选择Dbase/Foxpro(*.DBF)文件类型,再选中被破坏的数据库打开,这时不要做更改,只选择"保存"按钮,会出现"另存为"对话框,仍选择以原来文件名保存,会提示"文件已经存在,是否替换已有文件?",选择"是"。
然后选择"文件"菜单上的"关闭",会出现提示"数据库文件不是Excel格式,要保留修改吗?
要保存为Excel格式,单击’是’,然后在’保存类型’下拉列表框选’Excel工作簿’;
要用现有格式保存并替换原来的文件,单击’是’,然后单击’保存’;
要在关闭文件时维持现有格式并不作保存,单击’否’。"
由于我们并没有对数据库的记录进行改动,只是为了恢复数据库,所以选择最后一项"在关闭文件时维持现有格式并不作保存",因此单击"否",退出Excel。
启动Foxpro,再次打开数据库文件,发现数据库文件已可以被打开了,但是观察数据库的结构,会发现数据库结构中的索引不见了,不过数据库的索引文件还存在。我们只需要给数据库Add索引,并选择原来的索引文件Open即可。
添加索引文件后退出数据库结构设置,并对数据库重新索引一下,就可以继续使用原 来被破坏的数据库了。
你好,可以尝试以下方法:1、重穗迟新安装后的数据库,按以前表空间、数据文件进行创建。
2、用非系统盘的数据文件来顶替新创建的数据文件猜拍李。但系统的检查点变了数据库肯定不能启动。
3、要先脱机(Offline)非系统盘的文件,进行做一次价值贺燃恢复。
DBF格式文件被Excel打开时乱码显示,是因为打开的软件有问题,更换为notepad++打开。
工具/材料:以DBF格式文件、notepad++为例。
1、首先在桌面弊皮上,点击“notepad++”图标。
2、然后在该界面中,点击顶部功能栏里的“File”菜单里的“Open”功能。
3、之后在打开界面中,选中腊卜帆“DBF格式文件”,点击“打开”按钮。轮雹
4、最后在该界面中,显示DBF格式文件内容。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)