作为一个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('adodb.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\test.mdb')
---- 建立一个adodb.connection后,如果不需要返回操作结果(如删除,修改,更新等操作)就可以对数据库进行正常的sql操作了,此时应用adodb.connection的另外一个方法execute,使用语法为:
aconnection.execute( strsql );
---- 其中strsql为执行操作的sql语句,如删除操作可以为:delete from wfjcommu 用aconnection.close关闭一个数据库连接.
---- 2.数据集对象(adodb.recordset)
---- 如果要执行查询操作并返回查询结果,或者要更方便地操作数据表,就需要用到数据集对象了.
---- 数据集对象adodb.recordset的作用象delphi中的ttable或tquery对象.
---- 建立一个数据集对象的方法为(arecordset为variant类型变量):
----
arecordset:=createoleobject('adodb.recordset')
---- 从数据表取得数据的方法为open方法,具体使用方法为:
arecordset.open( strcommand,activeconnection, intcursortype,intlocktype, intcommandtype );
---- 其中: strcommand:字符串,为命令参数,可以是一个table名称,可以是一个sql语句,也可以是一个服务器上的存储过程(storedproc)名称,具体需要后面的参数intcommandtype来指定.
---- activeconnection:要使用的数据库连接,是一个adodb.connection对象.
---- intcursortype:长整数,数据集的cursor类型,可选参数,请参见程序中注释。
---- intlocktype:长整数,对数据表的加锁类型,可选参数,请参见程序中注释。
---- intcommandtype:长整数,命令参数的类型,用来指明strcommand的作用,可以指定strcommand为命令(如sql语句)或数据表(ttable)或储存过程(storedproc),可选参数,请参见程序中注释。
---- 如执行一个sql查询,可以采用如下语句:
arecordset.open('select
* from wfjcommu',adopenstatic,
adlockoptimistic,adcmdtext);
---- 其它常见属性和方法与ttable和tquery相比较如下(具体请见asp帮助文件):
eof,bof:eof,bof. movefirst, movelast:first, last moveprevious, movenext:prior, next move:moveby addnew:append update:post close:close
---- delete加update:delete,所有对数据表的修改均须用update使操作有效,这与delphi不同
fields[fieldno]:fields[fieldno]
fields['fieldname']:fieldbyname('fieldname')