在DELPHI程序中使用ADO对象存取ODBC数据库
2006-02-04 13:28:16 来源:WEB开发网---- 经过编程和测试,在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:Inetpubwwwroot est.mdb AConnection.open('Driver={Microsoft Access Driver (*.mdb)};DBQ=C:inetpubwwwroot est.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')
---- 3.其它常见对象(与Delphi对应的对象):
----
ADODB.Field:TField ADODB.Parameter:TPara ADODB.Error:EDBEngineError ADODB.Command:无 ADODB.Property:无
---- 下面来看一个应用例子,听别人说总不如自己看实际的例子来体会。在这个例子中,将演示如何利用ADO对象来对一个数据表进行查询、增加记录、修改记录和删除记录操作。具体的用法请参见程序中的注释,如果有点Delphi数据库编程经验,相信不难理解。
---- 在我们的例子使用的数据库为Test.MDB,其中有一个数据表为wfjcommu,有五个字段AName、Portable、Tel、BP、PostAddress,分别表示姓名、手机号、电话号码、呼机号码和通信地址。
----
procedure TForm1.Button1Click(Sender: TObject);{*****************************************************
---- 用ADO操作ODBC数据库本程序中,将创建一个临时的ODBC系统数据源,指向一个MsAccess数据库,然后对其中的数据表进行显示、增加、修改、删除和查询操作注意:请在Uses语句中包含ComObj单元
*****************************************************}const{ 一些常量声明,详细请参见adovbs.inc }{ ---- CommandType的常量说明 ---- } adCmdUnknown = 0008;//未知,需要系统来判断,速度慢,为缺省值 adCmdText = 0001;//命令语句如SQL语句 adCmdTable = 0002;//数据表名称 adCmdStoredProc = 0004;//存储过程名称{ ---- CursorType的常量说明 ---- } adOpenForwardOnly = 0;//只能由前向后单向访问,为缺省值 adOpenKeyset = 1;//可见其他用户对数据的修改,但对其它用户的增加和删除不可见 adOpenDynamic = 2;//其他用户对数据的增加修改和删除均可见 adOpenStatic = 3;//其他用户对数据的增加修改和删除均不可见{---- LockType的常量说明 ---} adLockReadOnly = 1;//只读,为缺省值 adLockPessimistic = 2;//在修改时,按单个记录锁定 adLockOptimistic = 3;//在修改后更新时,按单个记录锁定 adLockBatchOptimistic = 4;//在成批更新时记录锁定var AConnection, ARecordSet : variant; longintTemp : integer; strTemp : string; intIndex : integer;begin {创建一个临时的ODBC数据源, 指向一个MsAccess数据库, 并利用此DSN建立一个数据库连接} AConnection := CreateOleObject('ADODB.Connection'); AConnection.Open('Driver={Microsoft Access Driver (*.mdb)};DBQ=C:inetpubwwwroot est'); {建立一个数据集对象,并从数据表中提取数据} ARecordSet := CreateOleObject('ADODB.RecordSet'); ARecordSet.open( 'wfjcommu',AConnection, adOpenStatic,adLockOptimistic,adCmdTable ); memo1.lines.clear; memo1.lines.add('********数据表原有的内容如下********'); {显示各个域的域名} strTemp := '; for intIndex := 0 to ARecordSet.Fields.count - 1 do strTemp := strTemp + ARecordSet.Fields[intIndex].name+';'; memo1.lines.add( strTemp ); {显示各个域的内容} while not ARecordSet.eof do begin strTemp := '; for intIndex := 0 to ARecordSet.Fields.count - 1 do strTemp := strTemp + ARecordSet.Fields [intIndex].value+';'; memo1.lines.add( strTemp ); ARecordSet.MoveNext;//移到下条,Next end; {增加一个记录} ARecordSet.AddNew;//增加,Append ARecordSet.Fields['AName'] := '1'; //以FieldByName的方式存取 ARecordSet.Fields['Portable'] := '2'; ARecordSet.Fields(2) := '3'; //以Fields[index]的方式存取 ARecordSet.Fields(3) := '4'; ARecordSet.Fields(4) := '5'; ARecordSet.Update;//更新,Post ARecordSet.MoveFirst;//移到首条,First memo1.lines.add('********增加了一条 记录后的数据表的内容如下********'); {显示各个域的内容} while not ARecordSet.eof do begin strTemp := ';for intIndex := 0 to ARecordSet. Fields.count - 1 do strTemp := strTemp + ARecordSet.Fields[intIndex].value+';'; memo1.lines.add( strTemp ); ARecordSet.MoveNext;//移到下条,Next end; {修改最后一条记录} ARecordSet.MoveLast; ARecordSet.Fields['AName'] := '11'; //以FieldByName的方式存取 ARecordSet.Fields['Portable'] := '22'; ARecordSet.Fields(2) := '33'; //以Fields[index]的方式存取 ARecordSet.Fields(3) := '44'; ARecordSet.Fields(4) := '55'; ARecordSet.Update;//更新,Post ARecordSet.MoveFirst;//移到首条,First memo1.lines.add('********修改了最后一条 记录后的数据表的内容如下********'); {显示各个域的内容} while not ARecordSet.eof do begin strTemp := ';for intIndex := 0 to ARecordSet.Fields.count - 1 do strTemp := strTemp + ARecordSet.Fields[intIndex].value+';'; memo1.lines.add( strTemp ); ARecordSet.MoveNext;//移到下条,Next end; {删除最后一条记录} ARecordSet.MoveLast;//移到末条,Last ARecordSet.delete;//删除,delete ARecordSet.Update;//更新,在Delphi不需要 ARecordSet.MoveFirst;//移到首条,First memo1.lines.add('********删除了最后一条 记录后的数据表的内容如下********'); {显示各个域的内容} while not ARecordSet.eof do begin strTemp := '; for intIndex := 0 to ARecordSet.Fields.count - 1 do strTemp := strTemp + ARecordSet. Fields[intIndex].value+';'; memo1.lines.add( strTemp ); ARecordSet.MoveNext;//移到下条,Next end; ARecordSet.Close;{关闭数据集} {用SQL语句进行查询,查询姓名为“张三”的记录} {注意,在SQL语句中,字符串应该用单引号包括起来} ARecordSet.open( 'select * from wfjcommu where AName = '张三'', AConnection,adOpenStatic,adLockOptimistic, adCmdText ); memo1.lines.add('********张三的内容如下********'); memo1.lines.add( '共有' + IntToStr ( ARecordSet.RecordCount ) + '条匹配的记录' ); {显示各个域的内容} while not ARecordSet.eof do begin strTemp := '; for intIndex := 0 to ARecordSet.Fields.count - 1 do strTemp := strTemp + ARecordSet.Fields [intIndex].value+';'; memo1.lines.add( strTemp ); ARecordSet.MoveNext;//移到下条,Next end; {关闭数据集和数据库连接} ARecordSet.close; AConnection.close;end;
更多精彩
赞助商链接