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

在DEPHI程序中使用ADO对象存取ODBC数续

作者:闵涛 文章来源:闵涛的学习笔记 点击数:940 更新时间:2009/4/23 18:24:08
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( 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;

  以上程序在PWIN98+DELPHI3.0+PWS(Personal Web Server)4.0下调试通过.关于ADO对象的详细资料,请参见ASP帮助文件或Interdev帮助文件或OFFICE2000的有关文档.
 


没有相关教程
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

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

    同类栏目
    · C语言系列  · VB.NET程序
    · JAVA开发  · Delphi程序
    · 脚本语言
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉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……
    咸宁网络警察报警平台