欢迎来到天天文库
浏览记录
ID:20701144
大小:909.00 KB
页数:69页
时间:2018-10-15
《delphi第四章》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、第4章Delphi连接数据库的不同方式比较4.1BDE4.2ADO4.3dbExpress4.4ODBC4.5校务管理系统连接数据库4.1BDEBDE(BorlandDatabaseEngine)是Borland公司推出的一套数据引擎,用来实现应用程序与数据库之间的连接。使用BDE的时候,需要使用BDEAdministrator来配置一个别名,这个别名实质上是访问数据库的一个标识符,内部封装了访问数据库所需要的多个参数,如图4-1所示,不同的数据库所封装的参数是不一样的。图4-1一个完整的客户机/服务器数据库应用程序执行的时候,是通过BDE/IDAP
2、I与相应的特定数据库驱动程序相连接,再通过网络通信协议实现存取数据库。BDE/IDAPI隔离了应用程序与数据库,而Delphi中的数据集组件又隔离了操作界面与BDE/IDAPI的API,使程序员不需要了解太多的技术细节,就可以采用BDE/IDAPI,通过数据集组件来读写数据库。然而,了解BDE配置参数的含义有助于优化BDE。4.1.1BDE文件组成BDE所需要的一系列文件在默认情况下位于ProgramFilesBorlandBorlandSharedBDE目录下,包括不同类型数据的支持库、BDEAdministrator(bdeadmin.e
3、xe)、数据迁移工具(datapump.exe)、帮助文件等。BDE通常采用以下3种方式实现应用程序与数据库的连接。(1)采用Borland公司自己内置的驱动程序来连接数据库。一般应用在连接Pardox、dBase等数据库。(2)采用SQLLinks连接数据库。一般应用在客户机/服务器模式下的数据库应用程序开发。(3)采用ODBC方式连接数据库。一般应用在不具备内置驱动,又不具备SQLLinks驱动程序的数据库。如果数据库是MicrosoftAccess,则分发BDE相关文件的同时还要分发DAO(DataAccessObjects),它是基于COM技
4、术的数据访问API,提供了对Jet和ODBC的封装。4.1.2BDE组件在组件面板BDE页上集成了访问和管理BDE数据集的VCL组件,如图4-2所示。图4-2其中包括TTable、TQuery、Tdatabase等组件,这些都是不可见组件。Ttable代表任何数据库中的物理表或数据集,TQuery可实现单表或多表的查询,实现连接或嵌套的各种复杂查询,实现按照SQL合法语句完成的功能,例如Insert、Update、Drop等操作。4.1.3BDE手工配置在开发应用程序时,使用的数据库可以通过BDEAdministrator来进行配置。BDEAdmin
5、istrator可在Delphi安装程序组或者控制面版中打开。配置完成后,通过“Open”操作可以进行测试是否成功,如图4-3所示。图4-3如果配置BDE别名成功,可以使用Delphi自带的SQLExplore来打开其中的表、视图、存储过程等数据库对象。4.1.4程序设计中建立BDE别名在程序中建立BDE别名,需要使用BDE组件面板上的Database控件。操作步骤如下。(1)启动Delphi后,新建或选择已存在的DataModule,然后选择BDE组件面板,将Database控件添加到DataMoudle上,并取名为Database1。如图4-4所
6、示。图4-4(2)鼠标双击控件Database1,弹出如图4-5所示界面,进行别名参数设置。(3)单击“OK”完成BDE的设置。图4-5有以下两点需要注意。(1)在其他单元中,如果要使用所定义的Database,必须使用USE语句引入DataMoudle单元,否则无法实现关联引用。(2)把数据规则定义在同一模块是一种好的编程习惯,不但方便使用和维护,而且对于以后程序的扩展升级也方便,很容易迁移到三层或多层。所以建议将Database、Table、Query等对象创建到同一个DataMoudle管理模块中。4.1.5动态创建BDE别名程序中可以动态创建
7、BDE别名,以降低应用程序与数据库的关联密切性。下面给出一种解决方案。(假设应用程序工程文件为gxgl.prj,编译后生成的执行程序为gxgl.exe)(1)建立gxgl.ini文本配置文件(2)使用代码将gxgl.ini中数据库选项的内容读取到Database的参数列表中,实现应用程序与实际数据库的代码隔离。(3)在程序中,所有需要引用DataBaseName的BDE数据组件,其属性DataBaseName均引自该DataModle中的DataBase。4.1.6通过BDE别名查看数据库对象通过BDE别名查看数据库对象的操作步骤如下。(1)打开SQ
8、LExplore后,在Database列表中选择将要查看的BDE别名,如图4-6所示。图4-6(2)用鼠标单
此文档下载收益归作者所有