一般,ADO都是以同步的方式来处理数据。这就是说,当ADO开始处理数据后,应用程序必须等到ADO处理完毕之后才可以继续执行。但是除了同步执行方式之外,ADO也提供了异步执行的方式,允许当ADO处理时,应用程序仍然能够先继续执行。而当ADO处理数据完毕之后,ADO会以事件的方式通知应用程序,此时应用程序可以再根据ADO执行的结果来采取相应的动作。

使用异步执行方式有许多用途,例如,如果应用程序需要处理花费大量时间的动作,那么ADO可以选择以异步执行方式让ADO在后台执行,而让应用程序继续处理图形用户接口或用户输入的数据。

在ADO中使用异步执行方式非常简单,只需要对ADO数据集的ExecuteOptions属性值进行适当的设定即可。现在就让我们以一实际的范例应用程序来说明如何让ADO以异步的方式来处理数据。

1)在Delphi集成开发环境中关闭所有的项目。

2)建立一个新的应用程序项目,在主窗体中放入TADOConnection对象连接到数据库。

3)在主窗体中放入TADODataSet组件。设定它的Connection属性值为步骤2)的TADOConnection,并且在它的CommandText属性值中使用Select*fromADOTestDatas以取得所有的数据。再设定它的Active属性值为True以打开范例数据表。

4)放入TDataSource组件,设定它的DataSet属性值为步骤3)加入的TADODataSet组件。

5)放入TDBNavigator和TDBGrid组件,设定它们的DataSource组件为步骤4加入的TDataSource组件。

6)在主窗体中放入两个TButton组件以及一个TProgressBar组件,并且设定它的相关属性值。

7)最后在主窗体中放入一个TADOCommand组件。设定它的Connection属性值为步骤2)的TADOConnection,并且在它的CommandText属性值中使用Selectcount(*)fromADOTestDatas以便从ADOTestDatas数据表中取得所有数据的笔数。

8)在主窗体的OnActivate事件处理程序中撰写如下的程序代码:
procedureTForm1.FormActivate(Sender:TObject);
var
sRecNo:String;
begin
ProgressBar1.Max:=ADOCommand1.Execute.Fields.Item[0].Value;
sRecNo:=IntToStr(ProgressBar1.Max);
Self.Caption:='共有'+sRecNo+'笔数据';
end;
OnActivate事件处理程序首先执行TADOCmmand的SQL命令,并且从它回传的暂时Recordset对象中取出ADOTestDatas数据表中所有数据的笔数,然后再指定给TProgressBar的Max值,最后指定给窗体的Caption属性值。

9)双击窗体中的eoAsyncFetchNonBlocking按钮,并且在它的OnClick事件处
理程序中撰写如下的程序代码:
procedureTForm1.Button2Click(Sender:TObject);
begin
try
ADODataSet1.Active:=False;
ADODataSet1.ExecuteOptions:=[eoAsyncFetchNonBlocking];
finally
lStart:=GetTickCount;
ADODataSet1.Active:=True;
end;
end;
在上面的程序代码中先关闭步骤3)的TADODataSet,再设定它的ExecuteOptions属性值为使用异步方式来存取数据。最后再打开步骤3)的TADODataSet组件,从ADOTestDatas数据表中取得数据。

10)双击窗体中的eoAsyncFetch按钮,并且在它的OnClick事件处理程序中撰
写如下的程序代码:
procedureTForm1.Button1Click(Sender:TObject);
begin
try
ADODataSet1.Active:=False;
ADODataSet1.ExecuteOptions:=[eoAsyncFetch];
finally
lStart:=GetTickCount;
ADODataSet1.Active:=True;
end;
end;
在上面的程序代码中先关闭步骤3)的TADODataSet,再设定它的ExecuteOptions属性值为使用同步方式来存取数据,再打开步骤3)的TADODataSet组件,从ADOTestDatas数据表中取得数据。

在异步方式中,ADO会以OnFetchProgress事件来通知应用程序ADO还在处理数据之中,并且以OnFetchComplete事件来通知应用程序ADO已经处理数据完毕了。
程序员可以在这两个事件处理程序中撰写程序代码来处理这两种情形。下面是范例应用程序在这两个事件处理程序中实现的程序代码。

11)在步骤3)的TADODataSet组件的OnFetchProgress事件处理程序中撰写如下的程序代码:
procedureTForm1.ADODataSet1FetchProgress(DataSet:TCustomADODataSet;
Progress,MaxProgress:Integerv;arEventStatus:TEventStatus);
begin

//注意,每次循环的进度步距不是1,在这有可能是15,第一次提取的记录数量也很大,所以对于小数据量,没有意义
ProgressBar1.Position:=Progress;
end;
上面的程序代码只是在ADO持续处理数据时不断更新主窗体中TProgressBase
的显示状态。

12)在步骤3)的TADODataSet组件的OnFetchComplete事件处理程序中撰写如下的程序代码:
procedureTForm1.ADODataSet1FetchComplete(DataSet:TCustomADODataSet;
constError:Error;varEventStatus:TEventStatus);
begin
lEnd:=GetTickCount;
ShowMessage('总共花了'+FloatToStr((lEnd-lStart)/1000.0)秒+'');
end;
上面的程序代码是当ADO处理完数据之后便显示一个对话框,显示ADO处理数据所花费的时间。
现在请编译并且执行这个范例应用程序。图3-13是以异步的方式来存取ADOTestDatas这个范例数据表中数据的画面。从图中可以看到,当ADO存取数据时应用程序仍然可以不断地更新主窗体中的TprogressBar。如果使用同步的方式执
行,TProgressBar便无法这样更新状态。此时我们也可以移动主窗体的位置等,可见应用程序不会因为ADO在存取大量的数据而造成应用程序无法继续工作。

当ADO以异步的方式执行时,OnFetchProgress和OnFetchComplete事件可以帮助程序员取得非常有用的状态信息。

如果你也执行这个范例应用程序,那么可以比较一下当ADO在同步执行模式和异步执行模式中处理数据时哪一种模式比较有效率。可能你会惊讶地发现异步执行模式可以提供更好的执行效率

(邦畿千里,摘自李维《Delphi5.xADO/MTS/COM+高级程序设计篇》,并进行整理)

http://blog.csdn.net/shuaihj/article/details/3725786

ADO异步查询显示进度条的更多相关文章

  1. Asp.Net实现无刷新文件上传并显示进度条(非服务器控件实现)(转)

    Asp.Net实现无刷新文件上传并显示进度条(非服务器控件实现) 相信通过Asp.Net的服务器控件上传文件在简单不过了,通过AjaxToolkit控件实现上传进度也不是什么难事,为什么还要自己辛辛苦 ...

  2. (委托事件处理)关于多线程执行显示进度条的实例(转)&&线程间操作无效: 从不是创建控件“rtxtEntryNO”的线程访问它。

    关于多线程执行显示进度条的实例! 之前回答了一篇关于怎么在线程中操作进度条的帖子,估计有人看的不是很明白今天没事,写了一个小小的实例,很简单,就2个文件权当抛砖引玉,希望有更好解决方案的人发表一下意见 ...

  3. 任务栏显示进度条 CreateComObject(CLSID_TaskbarList) as ITaskbarList4

    http://www.cnblogs.com/jxsoft/archive/2011/06/02/2067712.html //在任务栏显示 进度条 unit Unit9; interface use ...

  4. WPF下载远程文件,并显示进度条和百分比

    WPF下载远程文件,并显示进度条和百分比 1.xaml <ProgressBar HorizontalAlignment="Left" Height="10&quo ...

  5. android标题栏(titlebar)显示进度条

    在后台线程中执行各种操作(网络连接.大数据存储)的时候,我们希望让客户能看到后台有操作在进行,那么既能有效的提示用户,又不占用当前操作空间,最好的方法就是在标题栏有个进度条. [代码] [Java]代 ...

  6. ProgressIndicator显示进度条以及一些文字信息

    //ProgressIndicator可以显示进度条以及一些文字信息,不过这个属性一般都在cs文件中操作. private void PhoneApplicationPage_Loaded(objec ...

  7. VC下载文件 + 显示进度条

    在codeproject里找了许久,发现这样一个VC下载文件并显示进度条的源码,于是添加了些中文注释: 1.下载线程函数: UINT DownloadFile(LPVOID pParam) { CWn ...

  8. VC下载文件显示进度条

    VC下载文件显示进度条 逗比汪星人2009-09-18上传   by Koma http://blog.csd.net/wangningyu http://download.csdn.net/deta ...

  9. C# WinFrom 导入Excel文件,显示进度条

    因为WINForm程序是在64位上运行如果使用另外一种快速的读取Excel的方法会报“未在本地计算机上注册“Microsoft.Jet.OLEDB.12.0”提供程序” 所以我就换了现在这种读取有点慢 ...

随机推荐

  1. android通过服务实现消息推送

    这里运用到的andorid知识模块主要有Notification和Service,和一个android-async-http-master开源框架 android项目中,有时会有这样一种需求:客户每隔 ...

  2. HDOJ 1005

    Input The input consists of multiple test cases. Each test case contains 3 integers A, B and n on a ...

  3. Android调整TimePicker和DatePicker大小

    最近写了个app,里面要将DatePicker和TimePicker并列显示.但是,Android内部把DatePicker和 TimePicker大小固定了,导致4.5寸手机屏幕一行只能显示出一个, ...

  4. WCF技术剖析之二十九:换种不同的方式调用WCF服务[提供源代码下载]

    原文:WCF技术剖析之二十九:换种不同的方式调用WCF服务[提供源代码下载] 我们有两种典型的WCF调用方式:通过SvcUtil.exe(或者添加Web引用)导入发布的服务元数据生成服务代理相关的代码 ...

  5. 通过 HTTPS 和 SSL 确保 Windows Azure 网站 (WAWS) 安全

    编辑人员注释:本文章由 Windows Azure 网站团队的项目经理 Erez Benari 撰写. 随着身份盗窃和各种形式的网络犯罪迅速增多,使用安全套接字层 (SSL) 对网站进行保护变得越来越 ...

  6. Oracle单表的简单查询

    Oracle单表的简单查询 查看表结构 desc emp; 查询所有列 Select * from emp; 查找所以部门编号(查指定的列) select deptnofrom emp; 查找编号不同 ...

  7. 普通图片转ascii码字符图

    效果图 基本思路 把图片每个像素点的信息拿出来,最重要的是拿到rgb的值 把每个像素点由rgb转成灰度图像,即0-255 给0-255分级,把每个等级的像素点转换成ascii码,完成 实现 第一步:获 ...

  8. 利用Winscp,Putty实现Windows下编写Linux程序

    本文讲的方案实现以下功能:利用winscp和putty的脚本功能,实现在Window平台上编写代码,上传到Linux进行编译,然后取编译结果.需要用到3个文件,分别如下: (1) synchroniz ...

  9. Bootstrap3学习笔记

    Bootstrap3简单介绍----专题1 声明:本文章是给初学bootstrap3的同学添加记忆的, 一定有非常多欠缺和不完好的地方, 希望能帮助到大家, 也希望能让很多其它的人了解boostrap ...

  10. Swift - 后台获取数据(Background Fetch)的实现

    前面讲了如何让程序申请后台短时运行.但这个额外延长的时间毕竟有限.所以从iOS7起又引入两种在后台运行任务的方式:后台获取和后台通知. 1,后台获取介绍 后台获取(Background Fetch)是 ...