|
在Delphi程序中使用ADO对象存取ODBC数 --------------------------------------------------------------------------------
作为一个ASP爱好者,笔者经常在ASP页面中使用ADO对象操作ODBC数据库,觉得用ASP创建Web应用系统确实是挺方便的。虽然在编程生涯中,笔者更喜欢Borland系列产品,对微软产品有点排斥,但对ASP却是例外。某天,忽然想到,ADO对象是一个标准OLE对象,如果在Delphi应用程序中能利用ADO操作数据库,应该挺不错。尤其在用DELPHI做网络数据库应用程序时,如果所在的Web站点是WINNT站点并且支持ASP页面,那就可以用ADO对象访问ODBC数据库,而不用把那么大的BDE再上载到站点上去。这样就可充分利用DELPHI和ASP的编程优势,做出更好的ISAPI/NSAPI/CGI。经过编程和测试,在Delphi中可以成功地用ADO对象存取ODBC数据库,现将本人的使用经验写出来,与大家共享,让我们多一个访问ODBC数据库的方法。
在32位的Delphi中,可以声明一个variant变量(如AVariant),然后通过CreateOleObject创建一个OLE对象,如AVariant:=CreateOleObject (’ADODB.Connection’)可以获得一个数据库连接对象的实例,然后就可以利用该对象的方法和属性来操作ODBC数据库了。 下面简单介绍一下访问ODBC数据库所用到的ADO对象及其方法和属性。
1、数据库连接对象(ADODB. Connection) 该对象用于与ODBC数据库建立连接,所有对数据库的操作均通过该连接进行。 数据库连接对象ADODB. Connection的作用象Delphi中的TDatabase对象。 建立一个连接对象的方法为(AConnection为Variant类型变量): AConnection:=CreateOleObject(’A DODB.Connection’) 用于建立连接的方法为Open,使用语法为(以对象AConnection为例): AConnection.Open( ConnectionString, UserId, PassWord ) 三个参数均为字符串类型,其中UserId和Password为用户名称和用户密码,用于访问数据库使用时可以省略,因为在ConnectionString同样可以指定用户名称和用户密码。ConnectionString是用来说明ODBC数据源信息的字符串,其格式为: ’Provider=ProviderName; DSN=DSNName; DRIVER=driver; SERVER=server; DATABASE=database; UID=user; PWD=password’ 其中: Provider:数据提供者,默认状态下为MSDASQL,为微软OLEDB,通常省略; DSN:要打开的数据库对应的OBDC系统数据源(DSN),是可选参数; DRIVER:要打开的数据库所用的驱动程序名称,如Access对应Microsoft Access Driver (*.mdb),是可选参数; SERVER:要打开的数据库所在的服务器名称,本机可用(local),是可选参数; DATABASE:要打开的数据库名称,是可选参数; UID:用户名称,用来访问数据库,是可选参数; PWD:用户密码,用来访问数据库,是可选参数。 以上参数均为可选参数,但必须提供足够的信息来描述一个系统数据源。 假如已经定义了一个ODBC的系统DSN,名称为MyDsn,那么就可用以下语句建立一个数据库连接: AConnection.Open(’DSN=MyDsn’); 为了防止DSN不存在或其设置被他人修改时造成应用程序运行错误,可以用ADODB.Connection 创建一个临时ODBC数据源,这样可以保证我们使用的系统DSN的参数设置是正确的。下面的语句可以创建一个临时ODBC系统DSN,对应一个ACCESS数据库,路径为C:Inetpub wwwroot test.mdb: AConnection.open(’Driver= {Microsoft Access Driver (*.mdb)};DBQ=C:inetpub wwwroot est.mdb’) 建立一个ADODB.Connection后,如果不需要返回操作结果(如删除,修改,更新等操作)就可以对数据库进行正常的SQL操作了,此时应用ADODB.Connection的另外一个方法Execute,使用语法为: AConnection.Execute( strSQL ); 其中strSQL为执行操作的SQL语句,如删除操作可以为:delete from wfjcommu。用AConnection.Close关闭一个数据库连接。
2、数据集对象(ADODB. RecordSet)
上一篇:用Delphi实现BP机、手机短讯
下一篇:Windows维护四步曲之系统清理
|