WIN7的 BDE administrstor 再哪里 啊

WIN7的 BDE administrstor 再哪里 啊,第1张

使用以前所写程序,采用BDE连接数据库,总是报错:
究其原因,是在BDE的安装中少了几个文件,复制过来就可以运行了,但在XP下是可以的,也就是说,这几个文件XP下是有的,Win7下面就没了。
三个文件ntwdblibdll﹑dbnetlibdll﹑dbnmpntwdll,复制到system下。

首先要在运行程序的机器上安装BDE驱动;
其次BDE使用的是本地数据库,如果一定要访问别人机器上的数据库,你可以考虑先设置自己机器里放数据库目录的共享属性,然后在别人的机器上为这个共享目录设置映射盘,然后再使用这个盘。
也可以试试以 \\ 开头的统一资源定位符形式来指定数据库路径。未试过,不知道能否成功

在这一章里我们主要介绍Delphi的数据访问部件的层次结构 多部件之间的关系 部件的属性 方法 事件以及各部件的应用 这些部件包括

● TSession部件

● 数据集部件(TTable和TQuery)

● TDatasource部件

● 字段对象TField

● 字段编辑器的使用

● TReport部件和TBatchMove部件

我们对这些部件的属性 方法和事件进行一般性的描述 读者在实际使用Delphi开发应用程序时 还可以通过联机帮助获得有关部件更详细的信息

Delphi数据访问部件的层次结构

Delphi提供了强大的开发数据库应用程序的能力 它给用户提供了大量的数据访问部件 以方便程序设计人员开发数据库应用程序 这些部件中 有些部件继承了另一些部件的属性 方法和事件 也就是说多部件之间存在着继承和被继承的关系 各部件的这种关联便构成了一个层次结构

TSession是全局性的部件 在应用程序运行时 它自动地建立 在设计阶段和运行过程中它是一个不可见的部件

TDatabase部件是为开发客户/服务器数据库应用程序时 设置登录的数据库的有关参数的 它在数据访问部件页上

TDataset部件是不可见的 TTable和TQuery部件是由它派生而来的 这两个部件一般被称为数据集部件 它们在数据访问部件页上

TDatasource部件是连接数据集部件和数据浏览部件的桥梁 它在数据访问部件页上

TFields部件对应于数据库表中的实际字段 它既可以在应用程序的运行过程中动态地生成也可以在程序设计阶段用字段编辑器创建 它是不可见的部件 在程序中我们可以通过TField部件来访问数据库记录的各个字段值

Tsession部件及其应用

TSession部件一般用得较少 但它对于一些特殊的应用是很有用的 在每一个数据库应用程序运行时Delphi自动地创建一个TSession部件 程序设计人既不能看见该部件也不能显示地创建一个TSession 部件 但是我们可以在应用程序中全局性地使用TSession部件的属性 方法

TSession部件的重要属性及作用

TSession部件的许多重要属性是用于控制数据库应用程序与数据库的连接的 在一个应用程序中 可以全局性地设置TSession的有关属性值 对与之相连接的磁盘上的数据库进行控制 TSession部件主要有下列属性

Database属性 是TSession中可以进行连接的所有数据库的数据库名字列表 这些数据库的名字常常是实际数据库的别名 包括数据库的路径 用户名 用户登录口令等参数

DatabaseCount属性 是TSession中可以进行连接的所有数据库的数量 它是一个整数

KeepCounnections属性 是一个布尔型属性 用它说明应用程序是否保持与一个非活动数据库的连接 因为对于一个数据库 当该数据库中没有相应的数据集部件(TTable或TQuery)被打开时 该数据库将自动地变成非活动的数据库 缺省情况下 KeePcounnections的值是True 就是说应用程序总是保持着与数据库的连接 即使数据库变成了非活动的数据库时 也是如此 如果将KeepConnections属性设置成False 那么当数据库由活动状态变成非活动状态时 应用程序与该数据库的连接也随之中断

NetFileDir属性 说明BDE网络控制文件的路径名

PrivateDir属性 说明存取临时文件的路径名

TSession部件的方法

TSession部件中的大部分方法是用于向用户提供与应用程序相连接的数据库的信息 如数据库的名字及别名 数据库中的表名以及数据库引擎BDE的有关参数等 在设计数据库应用程序时 想要获取有关数据库的信息 调用TSession部件的下列方法 将会大大简化程序的设计

GetAliasNames方法 调用该方法 我们可以获得数据库引擎BDE中定义的数据库别名

GetAliasParams方法 该方法主要用于获取我们在BDE中定义数据库别名时所说明的参数值 如BDE所在的目录路径以及实际名称等

GetDatabaseNames 方法 调用该方法可以帮助我们获得当前应用程序可以进行连接的所有数据库的名字 数据库的名字是用户使用BDE工具定义的实际数据库的别名

GetDriverNames方法 数据库引擎BDE可以与多种数据库管理系统相连接 如客户/服务器数据库管理系统Oracle Sybase以及本地数据库管理系统dBASE Paradox等 BDE与每一种数据库管理系统进行连接时 都有相应的驱动程序 而且这些驱动程序都可以选择地安装 通过调用GetDriverNames方法 我们可以获得当前BDE安装的数据库驱动程序的名字

GetDriverParams方法 BDE的数据库驱动程序中包含着多个参数 如支持的民族语言 DBMS的版本号 文件块大小等 对于服务器上的DBMS 还有数据库服务器的名字等等

GetTableNames方法 因为每一个数据库都是由多个数据库表组成的 我们通过说明数据库名 然后调用GetTableNames方法 便可以获得该数据库中全部的数据库表的名字

上述这些方法在调用时都需要一个字符串列表作为参数 而且都返回一个字符串列表的值

TSession部件还有一个叫DropConnections的方法用于控制应用程序与数据库的连接 当调用DropConnections方法时 应用程序与所有的数据库的连接将会切断

TSession部件应用举例

例 :我们创建一个应用程序 通过调用TSession有关的方法获取当前应用程序可以进行连接的数据库的名字以及获取其中任意一个数据库中的全部数据库表的名字

通过TSession部件获取数据库的有关信息

窗体中主要使用了两个列表框 其中列表框DatabaselistBox用于显示数据库的名字 列表框TablelistBox用于显示数据库中的表名 程序运行完后数据库的名字显示在DatabaselistBox列表框中 当用户单击DatabaselistBox列表框中的数据库名时 该数据库全部的数据库表的名字将会显示在TablelistBox列表框中 有关的程序代码如下

lishixinzhi/Article/program/Delphi/201311/25161

win7(64位) + Oracle 11g/12c 客户端(32位) + Delphi7(32位)
win7(64位) + Oracle 11g/12c 服务器端(32位) + Delphi7(32位)
因为Delphi7自带的BDE是32位,所以只能使用32位的Oracle客户端,数据库若是直接安装在本机,也务必安装32位版本Oracle。

为了便于开发数据库应用程序,在Delphi集成开发环境中,提供了大量的数据库工具软件用于帮助应用程序开发人员设计、编程、测试和发行数据库应用程序。所有这些工具构成了Delphi数据库应用程序开发环境。其各个工具软件及其相互间的关系。

整个Delphi数据库应用程序开发环境由数据库引擎(BDE)、数据库引擎管理程序(BDE Ad—ministrator)、数据库桌面(DataBase Desktop)、SQL浏览器(SQL Explorere)、SQL驱动程序(SQL Links)和ODBC驱动程序等组成。

数据库引擎是Delphi数据库开发环境的核心,它由两种类型的动态链接库组成:一种用于提供核心服务,另一种用于连接本地或网络数据库。所有这些文件被安装在 *** 作系统的System和用户所指定驱动器\Programe Files\Common Files\Borland\Bde\目录下。数据库引擎的主要 功能是将数据库应用程序和物理的数据库分隔开来,在数据库引擎中通过数据库别名(Database Aliases)来标识本地或远程的数据库,数据库应用程序仅需要此数据库别名就可以透明地对数据库进行访问。

数据库引擎管理程序(B DE Administrator)主要用于对本地的Paradox、dBASE数据表和远程的SQL数据库进行创建表、创建索引、查询、存取和我等 *** 作。

通过SQL浏览器可以对本地或远程的数据库进行各种SQL查询 *** 作。

SQL驱动程序(SQL Links)是Inprise公司在Delphi客户/服务器版本中提供的远程数据库的访问驱动程序,ODBC是微软公司在Windows 95/98或NT *** 作系统提供数据库访问驱动程序。

找到BDE安装目录,左边选择configuration选项卡,然后在树形菜单中依次选择Drivers、Native。然后选中oracle,右侧窗口找到SQLORA8DLL这一条,把它改成SQLORA32DLL。选择菜单object下的apply选项进行保存。然后退出。

这时启动Delphi应用依然报错,不过错误消息变成了

cannot load an IDAPI service library File: OCIDLL

估计这是因为oracle也是64位的,其中的ocidll不能被BDE驱动识别。
于是我再把环境变量中的Path增加一个路径: D:\Oracle11g\product\instantclient_11_2。

我没有看见过这样的书
只有一些例子介绍BDE的部署
转一个希望有帮助:
InstallShield Express for delphi制作安装程序定制BDE引擎 (转)
使用Delphi编写数据库程序,在发布程序的同时还需要发布BDE(Borland Database Engine),但BDE占用空间较大,如Delphi5就有174M之多,远比一般的程序本身要大。实际上,有些文件根本用不上,所以我们可以在发布时用Delphi附带的InstallShield Express for delphi制作安装程序来定制BDE引擎,这样就可以达到为我们的数据库应用程序“减肥”的目的。
下面介绍BDE引擎的各关键文件的作用,我们以此作为精简BDE驱动程序的依据:
一、不可缺少的文件
Blw32dll:语言驱动函数库。
Idapi32dll:BDE基本函数库。
Fareastbtl、Usabtl:远东语言及美国语言驱动程序,对中文软件不可缺少。
Idr20009dll:错误信息库。
二、数据库驱动程序(根据需要选择一个或多个)
Idasci32dll:Ascii文本数据库驱动程序函数库,如果不用Ascii文本数据库,可以不要。
Iddao32dll:Access数据库驱动程序函数库,如果不用Access数据库,可以不要。
Iddbas32dll:dBase数据库驱动程序函数库,如果不用dBase数据库,可以不要。
Idodbc32dll:ODBC数据库驱动程序函数库,如果不用ODBC数据库,可以不要。
Idpdx32dll:Paradox数据库驱动程序函数库,如果不用Paradox数据库,可以不要。
三、其它驱动程序和配置文件(根据需要选择一个或多个)
Idbat32dll:批 *** 作驱动程序函数库,如果不用TBatchMove控件或DbiBatchMove类函数,可以不要。
Iddr32dll:Data Repository驱动程序函数库,如果不用Data Repository功能,可以不要。
Idprov32dll:BDE DataSet provider驱动程序函数库,如果不用TProvider控件,可以不要。
Idqbe32dll:QBE驱动程序函数库,如果不用Query By Example,可以不要。
Idsql32dll:SQL查询驱动程序函数库,如果不用TQuery进行查询,可以不要。
Idapi32cfg:BDE配置文件,如果程序中没有特殊要求,可以不要。也可以在BDE管理器中设置正确后再分发。
四、其它文件(一般不用)
其它的BTL:其它国家和地区的语言驱动程序,可以不要。
BDE32HLP、BDE32CNT:BDE帮助文件,可以不要。
BdeAdminexe、BdeAdminHLP、BdeAdminCNT:BDE管理器及帮助文件,如果不会发生要求软件用户自己配置BDE的情况时,可以不要。
DataBumpEXE、DataBumpHLP、DataBumpCNT:数据库数据转移工具及帮助文件,可以不要。
LocalsqlHLP、LocalsqlCNT:SQL查询语句帮助文件,可以不要。
Sqllnk32HLP、Sqllnk32CNT:SQL连接帮助文件,可以不要。
根据需要选择文件后,还要写注册表文件。需要设置的注册表键值有:
数据驱动程序所在目录的设置:
HKEY_LOCAL_MACHINESoftwareBorlandDatabase EngineDLLPATH(字符串值)
语言驱动程序所在目录的设置:
HKEY_LOCAL_MACHINESoftware BorlandBLW32BLAPIPATH(字符串值)
语言驱动程序文件名:
HKEY_LOCAL_MACHINE SoftwareBorlandBLW32LOCALE_LIB#(字符串值) 其中#为编号,按顺序为0、1、2、3如:
HKEY_LOCAL_MACHINESoftwareBorlandBLW32LOCALE_LIB0="fareasstbtl" HKEY_LOCAL_MACHINESoftwareBorland BLW32LOCALE_LIB1="usabtl"
做完这些就足够了,按此办法即可有效减少BDE驱动程序的大小,例如只用TTable控件 *** 作Paradox数据库,则只要Idapi32dll、Blw32dll、Idr20009dll、Fareastbtl、Usabtl、Idpdx32dll六个文件即可。这些文件可放在任何一个目录,只要在注册表指明即可。BDE由174M减到148M,压缩一下就只有几百K了,这使程序大为减小。
下面我们就以用InstallShield Express for Delphi50来制作一个Paradox数据库应用系统的安装程序为例:
1 启动InstallShield Express for Delphi50程序;
2 设置New project对话框中有关文件目录路径,3 然后进入Setup Checklist;
4 在Set the Visual Design中设置程序名5 、程序目录、安装程序主窗口等信息;
6 在Specify Installshield objects for delphi5 中设置General Options,7 选择BDE数据库引擎;
8 在Specify Components and Files中设置Groups and Files项,9 在Program Files中加入用户的所有程序文件和数据库表文件,10 在BDE/IDAPI Files中删除除Idbat32dll、Usabtl、Idapicfg、Charsetcvb、Bantamdll、BLW32dll、Idapi32dll、Fareastbtl、Idpdx32dll、Idr20009dll、Idsql32dll以外的文件;
11 在Dialog Boxes中设置所需安装对话框;
12 在Make Registry Changes中设置Keys项,13 在HKEY_LOCAL_MACHINE中加入softwareborlandblw32和softwareborlanddatabase engine两项,14 并且在blw32的值中加入 “Blapipath ‘以上文件路径’”、“LOCALE_LIB0 ‘以上文件路径’Fareastdll”和“LOCALE_LIB1 ‘以上文件路径’Usadll”,15 在database engine值中加入“Dllpath ‘以上文件路径’”、“Configfile01 ‘以上文件路径’Idapicfg”;
16 在Specify Folder and Icons中根据实际要求设置有关项目;
17 在Run Disk Builder中设置安装盘的有关信息;
18 最后进行Test the Installation和Create Distribution Media即可完成安装程序的制作。

1、安装好bde;
2、安装好Mdac;(此项应该是odbc驱动for
MSSQLserver)
3、执行“windows的控制面板--管理工具--数据源(odbc)”,对MSSQLserver数据库建立相应的“系统DSN”;
4、执行bde配置程序,为上款的odbc数据源建立“alias别名”;
5、在delphi程序中
通过“别名”访问。
前提是你要设定好(本地或远程的)SQLserver数据库


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

原文地址: http://outofmemory.cn/yw/13383139.html

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

发表评论

登录后才能评论

评论列表(0条)

保存