有一段代码,采用了BDE数据库引擎,如果在某台机器上没有装BDE,请问要想该段代码能够运行,我该如何办?不要告诉我装一下BDE,因为用户是不能忍受这一点的!(5

  • 主题发起人 Blue_Fire
  • 开始时间
B

Blue_Fire

Unregistered / Unconfirmed
GUEST, unregistred user!
有一段代码,采用了BDE数据库引擎,如果在某台机器上没有装BDE,请问要想该段代码能够运行,我该如何办?不要告诉我装一下BDE,因为用户是不能忍受这一点的!(50分)<br />有一段代码,采用了BDE数据库引擎,如果在某台机器上没有装BDE,请问要想该段代码能够运行,我该如何办?不要告诉我装一下BDE,因为用户是不能忍受这一点的!
 
又想用BDE数据库引擎,又不想装BDE,那可能吗?
 
找出BDE需要的DLL打包到你的程序中
 
可以不全装BDE,但至少一两兆的DLL无论如何不能少,大小视连接的数据库而定,那改用

ADO算了,否则要想马儿跑的快,又不让吃草,可能么?再不然自己些地层的驱动,如封装

OCI?
 
那就不用BDE引擎,用ADO吧。
 
同意楼上,用ADO
 
考几个DLL文件就可以了,我记的大富翁以前有个这个问题。
 
打包几个DLL文件就可以了。我记的以前大富翁上有过这个问题。
 
to hunhun: 具体是哪几个dll? thanks!
 
节选,供参考:
  Blw32.dll:语言驱动函数库
  Idr20009.dll:错误信息库
  Fareast.bll:远东语言驱动程序
  Usa.bll:美国语言驱动程序
  以下文件为根据需要可选:
  如用Paradox,则应选择:Idpdx32.dll
  如用Dbase,则应选择:Iddbas32.dll
  如用Access,则应选择:Iddao32.dll
  如用Ascii,则应选择:Idasci32.dll
  如用TBatchMove,则应选择:Idbat32.dll
  如用Data Repostitory,则应选择:Iddr32.dll
  如用ODBC,则应选择:Idodbc32.dll
  如用BDE DataSet Provider DLL,则应选择:Idprov32.dll
  如用SQL查询,则应选择:Idsql32.dll
  以用InstallShield来制作一个Paradox数据库应用系统的安装程序为例:
  1.启动程序设置有关文件目录路径,进入Setup Checklist;
  2.在Set the Visual Design中设置程序名、程序目录、安装程序主窗口等;
  3.在Specify Components and Files中设置Groups and Files项,在Program Files中加入用户的所有程序文件和数据库表文件,
以及下列文件:Idbat32.dll、
Usa.btl、Idapi.cfg、Charset.cvb、Bantam.dll、BLW32.dll、Idapi32.dll、Fareast.btl、Idpdx32.dll、Idr20009.dll、
Idsql32.dll(以上文件必须含目录路径);
  4.在Dialog Boxes中设置所需安装对话框;
  5.在Make Registry Changes中设置Keys项,在HKEY_LOCAL_MACHINE中加入software/borland/blw32和software/borland/database engine两项,
并且在blw32值中加入
  “Blapipath ‘以上文件目录’”、“LOCALE_LIB0 ‘以上文件目录’/Fareast.bll”和“LOCALE_LIB1 ‘以上文件目录’/Usa.bll”,
在database engine值中加入“Dllpath ‘以上文件目录’”、“Configfile01 ‘以上文件目录’/Idapi.cfg”;
  6.在Specify Folder and Icons中根据实际要求设置有关项目;
  7.在Run Disk Builder中设置安装盘的有关信息;
  8.最后进行Test the Installation和Create Distribution Media即可完成安装程序的制作


假设你的程序路径c:/myexe 你的exe和数据库文件.db等放在这个文件夹
1。新建bde子文件夹 c:/myexe/bde
2。这些文件丛delphi的bde文件夹里找到并拷贝倒c:/myexe/bde
:Bantam.dll、blw32.dll、usa.btl、Charset.cvb、Fareast.btl、
idapi32.dll、idbat32.dll、idpdx32.dll、idr20009.dll、idsql32.dll
3。在注册表中设置:
建立 HKEY_LOCAL_MACHINE/SOFTWARE/Borland/BLW32
下面设置键:BLAPIPATH 字符串型 值为c:/myexe/bde
建立 HKEY_LOCAL_MACHINE/SOFTWARE/Borland/Database Engine
下面设置键:DLLPATH 字符串型 值为c:/myexe/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六个文件即可。

---- 这些文件可放在任何一个目录,只要在注册表指明即可。OK,BDE由9M多减到不到2M,ZIP一下就700多K了,比原来的应用系统减少了不少吧。
 
使用的数据库系统文件:bde子系统
Bantam.dll、
blw32.dll、
usa.btl、
Charset.cvb、
Fareast.btl、
idapi32.dll、
idbat32.dll、
idpdx32.dll、
idr20009.dll、
idsql32.dll
上面说得太麻烦了,我这是win2000+d6通过的
假设这些文件你拷贝到 c:/bde 文件夹
需要注册这两个值就可以了:
HKEY_LOCAL_MACHINE/SOFTWARE/Borland/BLW32 下 BLAPIPATH=c:/bde
HKEY_LOCAL_MACHINE/SOFTWARE/Borland/Database Engine 下 DLLPath=c:/bde
 
要不就装BDE,要不就用ADO算了
 
顶部