我用DELPHI写了一个程序, 其中有一个DBF文件,在调试的时候可以用的好好的,但是等我把全部代码写完,发现一个大问题
   如果在其他的机器上使用时,如果这台机器没有安装DELPHI,或DBE,或者其他的可以识别DBF文件的工具外,  这个程序是无法正常运行的。请问各位有没有什么好的方法,,,现在真的很急。谢谢先

解决方案 »

  1.   

    你可以在他的机器上装上一个比较小的bde.具体方法如下:
    精简Delphi数据库应用系统-定制BDE驱动程序------------------------------------------------------------------------------------ Delphi程序员都知道,在数据库应用程序开发完成后,要发布程序需要同时发布BDE(Borland Database Engine),否则会引起错误“A Error occurred while attempingto initilize Borland Database Engine(Error $2109)”。当觉得程序太大而辛辛苦苦精简自己的程序到满意时,却发现BDE管理程序器需要9M之巨,不由感到沮丧,真有点自己的努力被糟蹋的感觉。不过也不必太沮丧,只要肯尝试,还是有办法来精简BDE的。 ---- 首先来看看BDE目录中的文件,所有文件确实有近9M大吧。不过有些可能是用不到的,关键文件的作用可参见Bde32.HLP中“Introduction to Borland Database Engine”下的“Core BDE Files”,其中列出了BDE的关键文件及其作用,可以以此作为依据来尝试精简BDE驱动程序。下面是各个文件的作用: ---- 一、不可缺少的文件 ---- Blw32.dll:语言驱动函数库。 ---- Idapi32.dll:BDE基本函数库。 ---- Fareast.bll、Usa.bll:远东语言及美国语言驱动程序,对中文软件不可缺少。 ---- Idr20009.dll:错误信息库。 ---- 二、数据库驱动程序(根据需要选择一个或多个) ---- Idasci32.dll:Ascii文本数据库驱动程序函数库,如果不用Ascii文本数据库,可以不要。 ---- Iddao32.dll:Access数据库驱动程序函数库,如果不用Access数据库,可以不要。 ---- Iddbas32.dll:dBase数据库驱动程序函数库,如果不用dBase数据库,可以不要。 ---- Idodbc32.dll:ODBC数据库驱动程序函数库,如果不用ODBC数据库,可以不要。 ---- Idpdx32.dll:Paradox数据库驱动程序函数库,如果不用Paradox数据库,可以不要。 ---- 三、其它驱动程序和配置文件(根据需要选择一个或多个) ---- Idbat32.dll:批操作驱动程序函数库,如果不用TBatchMove控件或DbiBatchMove类函数,可以不要。 ---- Iddr32.dll:Data Repository驱动程序函数库,如果不用Data Repository功能,可以不要。 ---- Idprov32.dll:BDE DataSet provide驱动程序函数库,如果不用TProvider控件,可以不要。 ---- Idqbe32.dll:QBE驱动程序函数库,如果不用Query By Example,可以不要。 ---- Idsql32.dll:SQL查询驱动程序函数库,如果不用TQuery进行查询,可以不要。 ---- Idapi32.cfg:BDE配置文件,如果程序中没有特殊要求,可以不要。也可以在BDE管理器中设置正确后再分发。 ---- 四、其它文件(一般不用) ---- BDE32.HLP、BDE32.CNT:BDE帮助文件,可以不要。 ---- BdeAdmin.exe、BdeAdmin.HLP、BdeAdmin.CNT:BDE管理器及帮助文件,如果不会发生要求软件用户自己配置BDE的情况时,可以不要。 ---- 其它*.BLL:其它国家和地区的语言驱动程序,可以不要。 ---- DataBump.EXE、DataBump.HLP、DataBump.CNT:数据库数据转移工具及帮助文件,可以不要。 ---- Localsql.HLP、Localsql.CNT:SQL查询语句帮助文件,可以不要。 ---- Sqllnk32.HLP、Sqllnk32.CNT:SQL连接帮助文件,可以不要。 ---- 在根据需要选择文件后,还要写注册表文件。这个应该不成问题,可以手工设置,但最好在程序中设置,在发现注册表中没有相应键值时写入,用TRegFile对象用不了几行代码的。需要设置的注册表键值有(在调用数据库操作前需要有正确的键值存在): ---- 数据驱动程序所在目录的设置: ---- HKEY_LOCAL_MACHINE\Software\Borland\Database Engine\DLLPATH(字符串值) ---- 语言驱动程序所在目录的设置: ---- HKEY_LOCAL_MACHINE\Software \Borland\BLW32\BLAPIPATH(字符串值) ---- 语言驱动程序文件名:HKEY_LOCAL_MACHINE\ Software\Borland\BLW32\LOCALE_LIB#(字符串值)  其中#为编号,按顺序为0、1、2、3......如:
     HKEY_LOCAL_MACHINE\Software\Borland\
    BLW32\LOCALE_LIB0="fareasst.bll"
     HKEY_LOCAL_MACHINE\Software\Borland
    \BLW32\LOCALE_LIB1="usa.bll"
    ---- 就这些了,按此办法即可有效减少BDE驱动程序的大小,例如只用TTable控件操作Paradox数据库,则只要Idapi32.dll、Blw32.dll、Idr20009.dll、Fareast.bll、Usa.bll、Idpdx32.dll六个文件即可。(破天惊补充:bantam.dll也必须有!) ---- 这些文件可放在任何一个目录,只要在注册表指明即可。OK,BDE由9M多减到不到2M,ZIP一下就700多K了,比原来的应用系统减少了不少吧。
      

  2.   

    用ADO连吧,到MS的网站下载MDAC2。8,安装试试
      

  3.   

    不好啦。。
         史弟们,我刚才将那个BDE全部打包进去了,原先那个错误的确是没有了,
    但是在使用中又报出了这样的错误。
      [Microsoft ][ODBC dBase Driver]外部表不是预期的格式。我记得好像要写一个ini文件,特别是在使用ACCESS做数据库时,但是我不知道这个INI文件应该怎么写。。 求各位大侠帮忙了。。
      

  4.   

    你怎么写的啊?
    我习惯ADO,没有这方面的问题!
    不会有这些问题啊!我以前做一个考试系统,动态生成DBF表!
      

  5.   

    你先在ODBC里里面连接这个DBF文件,测试成功以后再到BDE里面设置才可以打开.不要只修改BDE里面的参数,那样是没有用的.