填写数据(Filling some data)
为了有一些“哑元”(dummy)数据,在类型(Type)表中填上以下4个记录:“游戏(Game)”,“数据库(Database)”,“互联网(Internet)”,“图形(Graphics)”。在选择存储在应用程序表(Applications)中的应用程序类型时,这些值将被使用。 接下来,在作者表(Authors)中增加一行:'Delphi Guide'、'delphi.guide@about.com'、 'http://delphi.about.com'。最后,在应用程序表(Applications)中加上一行:'Zoom'、'Zooming the Destop'、'Delphi Guide'、'Graphics'、10、0、02/20/2001,同时让最后一个字段(照片)为空。
怎样处理这些“空”(blank)的数据库......在本教程的余下章节将进行说明。
第二章 连到数据库,用ADO? BDE?
第一节 Delphi数据库连通性
像在上一章中所显示的那样,数据库是以一定的结构格式存储数据的一个或多个表的集合。这些表包含以行、列的形式表现的数据。当一个数据库包含一个或多个表时,这些表通常拥有分散但相关的数据。MS Access、Interbase、SQL Server用一个文件表示完整的数据库(MS Access是*.mdb文件)。另一方面,Paradox和dBase由代表索引和表关系的单独的表和文件定义。描述Paradox数据库的所有文件通常存放在一个目录中。当然,Delphi可以以这两种方式工作。
用Delphi,我们可以连到不同类型的数据库:本地或C/S(远程服务器)数据库。本地数据库存放在本地驱动器或本区域网中。远程数据库服务器通常位于远端机器。本地数据库的类型有Paradox、dBase和MSAccess。C/S数据库有MS SQL Server、Interbase或Oracle。
本地数据库通常被称为单层数据库。单层数据库对任何变化如:编辑数据、插入记录、或删除记录-立即实现。单层数据库在表所容纳的数据量大小和应用程序所支持的用户量的多少上有限制。当数据库包含几个表之间复杂关系的信息时,或当客户端数量增加时,你需要使用二层或多层应用程序。客户端应用程序在本地机上运行;应有程序服务器多运行在服务器上,而数据库可能位于另一个服务器。多层体系的思路是客户端程序可以非常小,因为应用程序服务器可以完成很多工作。这可以使你编写所谓瘦客户端应用程序。
当我们用Delphi编写数据库应用程序时,我们需要用一些数据库引擎访问数据库的数据。数据库因请允许你把焦点集中在你所访问的是什么数据,而不是怎样访问它。从第一版开始,Delphi就为数据库开发人员提供了BDE(Borland Database Engine)。除了BDE外,从第五版开始,Delphi提供对微软的ADO数据库接口的支持。
本教程将重点关注用MS Access本地数据库开发单层数据库应用程序。
第二节 Borland 数据库引擎(BDE)
BDE是所有Borland产品—包括Delphi和C++Builder—时共同的数据访问层。BDE是一个DLL(Dynamic Link Libraries)和工具的集合。它的漂亮之处在于所有的数据处理对于开发者都是透明的。BDE带有一套驱动,可以使你的应用程序与多种不同类型的数据库进行交流。这些驱动把高层次数据库命令(如open或post)和任务(记录锁定或SQL结构)转化为特殊的数据库类型所需要的特定命令,这些特殊的数据库有:Paradox、dBase、MS Access或任何ODBC数据源。BDE API (Application Programming Interface 应用程序编程接口)包含200多个过程和函数,它们可以从BDE单元获得。幸运的是,你几乎根本不需要直接调用这些程序。相反地,你通过VCL(译者加:Visual Component Library可视组件库)的数据访问组件—位于组件面板的数据访问页(Data Access)使用BDE。为了访问特殊的数据库,应用程序只需知道数据库的别名(Alias)就可以访问该数据库的所有数据。别名在BDE管理器(BDE Administrator)中建立,它指定了驱动器的参数和数据库的位置。BDE自带一个数据库驱动集,可以访问大范围不同类型的数据元。标准的BDE驱动包括Paradox、dBase、MS Access、ASCII文本。当然,任何ODBC驱动器也能通过ODBC管理器(ODBC Administrator)被BDE使用。
使用BDE访问数据库的Delphi应用程序需要为应用程序分发BDE。当配置应用程序的BDE时,你必须使用InstallShield Express或别的Borland指定的安装程序。
BDE作为数据库引擎有其优点也有其缺点。但是,在本教程中将不讨论为什么和什么时候你应该(或不应该)使用BDE方法而不是某些非BDE技术。
既然本教程是讨论ADO/MSAccess的,那么余下部分将集中在这种非BDE的数据库方法。
2002年12月22日