如何解决dbc数据库文件破坏问题

如何解决dbc数据库文件破坏问题,第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打开试一试

如果 所有的检索条件,都是 RTRIM(LOT.CASE_MARK_ORDER_NO) = ..

不存在 直接 LOT.CASE_MARK_ORDER_NO = .. 的情况的话。

方案一:创建基于 函数的索引

方案二:假如 CASE_MARK_ORDER_NO 长度为 20

那么 LOT.CASE_MARK_ORDER_NO = RPAD('{0}', 20)

也就是 通过 把检索条件的字符串,补上足够的长度,来进行匹配,而使索引的使用有效。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9953300.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-03
下一篇2023-05-03

发表评论

登录后才能评论

评论列表(0条)

    保存