转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 站长学院 >> Web开发 >> 正文
在DELPHI程序中使用ADO对象存取ODBC数据库         ★★★★

在DELPHI程序中使用ADO对象存取ODBC数据库

作者:闵涛 文章来源:闵涛的学习笔记 点击数:1408 更新时间:2009/4/23 10:48:39
作为一个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'''')

 

----   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:\inetpub\wwwroot\test'''');

  {建立一个数据集对象,并从数据表中提取数据}
  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(

[1] [2]  下一页


[Delphi程序]在Delphi里调用API函数动态建立ODBC数据源。  [VB.NET程序]ADO 在informix的 Addnew
[VB.NET程序]ADO 的测试  [VB.NET程序]ADO 揭密 1
[网页制作]Ultradev实例教程:2.2 用ODBC连接数据库  [Web开发][ADO]如何修改ADO的线程模型
[Web开发]Delphi7下仿Ado.Net类的实现  [Web开发]通过COM使用ADO
[Web开发]ADO & ADO.NET中使用存储过程的两个共用的函数  [Web开发]Binding a DataGrid to an ADO Recordset
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Web开发  · 网页制作
    · 平面设计  · 网站运营
    · 网站推广  · 搜索优化
    · 建站心得  · 站长故事
    · 互联动态
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台