|
详细介绍notatable/dbf错误的解决方法
( 2008/3/26 10:45 )
目前有相当一部分正在运行应用程序是用Foxpro 编写的,由于突然断电、程序非法关闭等原因,经常会导致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、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即可。 添加索引文件后退出数据库结构设置,并对数据库重新索引一下,就可以继续使用原 来被破坏的数据库了。
|
·技巧实例:如何在.NET中访问MySQL数据库 (9-25) ·有关PB/Sybase开发过程中数据库转移介绍 (9-25) ·SQL Server 2008数据库中如何使用表值参数 (9-25) ·甲骨文推“数据库机器” 首涉电脑硬件销售 (9-25) ·入门级的ORACLE数据库备份与数据库还原 (9-24) 热议文章·高端的口号低端的招标 电信招标有类联通 (9-18) 评:其实我觉得电信可以采用机卡一体机和机卡分离机并举的形式解决终端问题,毕竟世界范围... ·重组后的中国联通,何以对抗即将到来的混战 (9-17) ·中国移动新一轮TD招标重点发生变化 (9-8) ·我的e家遭家庭计划冲击 中移动掀家庭市场之战 (9-7) ·联通网通合并后名称暂定为联合网络通信公司 (8-27) ·左迅生感叹网通品牌会消失 称合并后不会裁员 (8-26) ·中移动竞夺CDMA集团用户方案曝光 (8-25) ·英特尔 凌动230 Shelton平台 (9-28) ·英特尔凌动 N270 Navy Pier平台 (9-28) ·Menlow平台架构 (9-28) ·英特尔 Atom(凌动) 处理器 (9-28) ·金龙公司简介 (9-28) ·甘肃电网圆满完成神七发射保电 (9-28) |
|||||||||||||||
|