赛迪网 > IT技术 数据库 > 精彩更新
  IT资讯搜索
 
IT产品搜索
[程序开发][网管世界][网络安全][数据库技术]
[操作系统][嘉宾聊天·在线访谈][活动集锦]
[精彩专题][Symantec专区][订阅IT技术周刊]
[开发论坛][网管论坛][安全论坛][数据库论坛]
[操作系统论坛][Sybase专区][IBM dW技术专区]
[病毒求助][病毒与漏洞播报][文档·源码下载]

实例解析:修复被破坏的Foxpro数据库

发布时间:2007.08.27 05:13     来源:赛迪网    作者:yangguo

目前在我国,有相当一部分正在运行应用程序是用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即可。

添加索引文件后退出数据库结构设置,并对数据库重新索引一下,就可以继续使用原 来被破坏的数据库了。 (责任编辑:卢兆林)


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· 新一代的三层架构利器数据库开发工具 (08-26) · 为什么Access数据库的精髓不在VBA之中 (08-26)
· 细化解析:从数据库创建工作流应用程序 (08-26) · 细化解析:轻松掌握数据库的工作原理 (08-26)
· 深入了解:由国人自主研发的达梦数据库 (08-26) · 解析数据库使用和开发中的十个常见错误 (08-26)
· 解析数据库应用程序中的术语和概念 (08-24) · 怎样才能有效的限制特定的IP访问数据库 (08-24)
· 如何在安装包中自动为客户创建数据库 (08-24) · 教你使用数据库建模工具进行数据库建模 (08-23)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
  赛迪推荐  
  手机·资费 ·新品·导购·评测·手机资费·宽带
手机搜索  诺基亚 N73 MOTO Z6
  IT产品 ·笔记本·台式机·服务器·打印·投影
IT产品搜索 
  IT技术 ·开发·网管·安全·数据库·操作系统
  信息化 ·热点·专题·访谈·周刊·方案案例
[政务][电信][金融][农业][制造业][中小企业]
[CIO][ERP][协同][IT管理][中间件][电子商务]
[政策][地方][专家][评估][辞典][博客][社区]
· 专题:一路畅通构想曲——让出行不再遭遇堵车
· CIO工作亲历:企业ERP选型不能忽视"选人关"
· 综述:信息化建设给中国监狱带来的各种变化
· 金融业风险管理和法规遵从有五点需考虑的因素
· 保险业CIO关注:该如何建立统一高效的CRM体系
· 调查显示:多数CIO对IT规划仍存在困惑和误解
  博客·论坛 ·曾剑秋·项立刚·Java学习·网管