当前位置:首页 > 网络编程 > 软件语言 > DELPHI > Delphi中实现多线程同步查询

Delphi中实现多线程同步查询

点击次数:62 次 发布日期:2008-11-09 08:37:49 作者:源代码网
源代码网推荐
广告载入中
优秀的数据库应用应当充分考虑数据库访问的速度问题。通常可以通过优化数据库、优化 查询语句、分页查询等途径收到明显的效果。即使是这样,也不可避免地会在查询时闪现一个带有 SQL符号的沙漏,即鼠标变成了查询等待。最可怜的是用户,他(她)在此时只能无奈地等待。遇到急性子的,干脆在此时尝试 Windows中的其它应用程序,结果致使你的数据库应用显示一大片白色的窗口。真是无奈!
源代码网推荐 本文将以简单的例子告诉你如何实现线程查询。还等什么,赶快打开Delphi对照着下面的完整源代码试试吧。 在查询时能够做别的事情或者取消查询,这只是基本的线程查询,在你阅读了Delphi有关线程帮助之后能立刻实现。这里介绍的是多个线程查询的同步进行。
源代码网推荐 在Delphi数据库应用中,都有一个缺省的数据库会话 Session。通常情况下,每个数据库应用中只有这一个会话。无论是查询函数修改数据,在同一时间内只能进行其中的一件事情, 而且进行这一件事情的时候应用程序不能响应键盘、鼠标以及其它的 Windows消息。这就是在 窗口区域会显示一片空白的原因所在。当然,只要将查询或数据操纵构造成线程对象,情况会好一些,至少可以接受窗口消息,也可以随时终止查询或数据操纵,而不会在屏幕上显示出太难看的白色。不过,这只是解决了问题的一部分。假如在进行一个线程查询的时候,用户通过 按钮或菜单又发出了另一个查询的命令,这可如何是好,难道终止正在执行的数据库访问吗? 解决之道就是:多线程同步查询。


源代码网推荐
源代码网推荐 实现多线程同步查询的基本思想是,为每一个查询组件(如TQuery组件)创建一个独占的 数据库会话,然后各自进行数据库访问。需要特别注意的是,因为Delphi中的 VCL组件大多都 不是线程安全的,所以应当在线程查询结束后再将DataSource组件与查询组件关联,从而显示 在DBGrid组件中。
源代码网推荐
源代码网推荐 下面的例子只实现了静态的线程同步查询,即线程对象是固定的,并随窗体的创建和销毁 而创建和销毁。你可以就此进行改进,为每一个数据查询或数据操纵命令创建一个单独的线程对象,从而达到多线程同步查询的目的。
源代码网推荐
源代码网推荐 注意:应用程序中的线程不是越多越好,因为线程将严重吞噬CPU资源,尽管看上去并不明显。谨慎创建和销毁线程将避免你的应用程序导致系统资源崩溃。
源代码网推荐
源代码网推荐 下面的例子给出了同时进行的两个线程查询。第一次按下按钮时,线程开始执行;以后每次按下按钮时,如果线程处于挂起状态则继续执行,否则挂起线程;线程执行完毕之后将连接 DataSource,查询结果将显示在相应的DBGrid中。
源代码网推荐
源代码网推荐 { 这里的多线程同步查询演示程序仅包括一个工程文件和一个单元文件 }
源代码网推荐 { 窗体中放置的组件有: }
源代码网推荐 { 两个Session组件 }
源代码网推荐 { 两个Database组件 }
源代码网推荐 { 两个Query组件 }
源代码网推荐 { 两个DataSource组件 }
源代码网推荐 { 两个DBGrid组件 }
源代码网推荐 { 一个Button组件 }
源代码网推荐 { 除非特别说明,否则上述各组件的属性都取默认值(见各组件注释) }
源代码网推荐 { 对于Database组件,就和一般设置一样,有一个正确的连接即可 }
源代码网推荐 { 对于Query 组件,需要在各自的属性 SQL中添加一些查询语句,为了 }
源代码网推荐 { 看得更清除,建议不要在两个Query 组件中填写相同的查询语句。 }
源代码网推荐
源代码网推荐 unit Unit1;
源代码网推荐
源代码网推荐 interface
源代码网推荐
源代码网推荐 uses
源代码网推荐 Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
源代码网推荐 Db, DBTables, Grids, DBGrids, StdCtrls;
源代码网推荐
源代码网推荐 type
源代码网推荐 TForm1 = class(TForm)
源代码网推荐 Session1: TSession; { 属性SessionName填写为S1 }
源代码网推荐 Database1: TDatabase; { 属性SessionName选择为S1 }
源代码网推荐 Query1: TQuery;{ 属性Database选择为Database1;属性SessionName选择为S1 }
源代码网推荐 DataSource1: TDataSource; { 属性DataSet设置为空 }
源代码网推荐 DBGrid1: TDBGrid; { 属性DataSource选择为DataSource1 }
源代码网推荐 Session2: TSession; { 属性SessionName填写为S2 }
源代码网推荐 Database2: TDatabase; { 属性SessionName选择为S2 }
源代码网推荐 Query2: TQuery;{ 属性Database选择为Database2;属性SessionName选择为S2 }

源代码网推荐 DataSource2: TDataSource; { 属性DataSet设置为空 }
源代码网推荐 DBGrid2: TDBGrid; { 属性DataSource选择为DataSource2 }
源代码网推荐 BtnGoPause: TButton; { 用于执行和挂起线程 }
源代码网推荐 procedure FormCreate(Sender: TObject); { 创建窗体时创建线程对象 }
源代码网推荐 procedure FormDestroy(Sender: TObject); { 销毁窗体时销毁线程对象 }
源代码网推荐 procedure BtnGoPauseClick(Sender: TObject); { 执行线程和挂起线程 }
源代码网推荐 private
源代码网推荐 public
源代码网推荐 end;
源代码网推荐
源代码网推荐 TThreadQuery = class(TThread) { 声明线程类 }
源代码网推荐 private
源代码网推荐 FQuery: TQuery; { 线程中的查询组件 }
源代码网推荐 FDataSource: TDataSource; { 与查询组件相关的数据感知组件 }
源代码网推荐 procedure ConnectDataSource;{ 连接数据查询组件和数据感知组件的方法 }
源代码网推荐 protected
源代码网推荐 procedure Execute; override;{ 执行线程的方法 }
源代码网推荐 public
源代码网推荐 constructor Create(Query: TQuery;
源代码网推荐 DataSource: TDataSource); virtual; { 线程构造器 }
源代码网推荐 end;
源代码网推荐
源代码网推荐 var
源代码网推荐 Form1: TForm1;
源代码网推荐 Q1, { 线程查询对象1 }
源代码网推荐 Q2: TThreadQuery; { 线程查询对象2 }
源代码网推荐
源代码网推荐 implementation
源代码网推荐
源代码网推荐 {$R *.DFM}
源代码网推荐
源代码网推荐 { TThreadQuery类的实现 }
源代码网推荐
源代码网推荐 { 连接数据查询组件和数据感知组件}
源代码网推荐 procedure TThreadQuery.ConnectDataSource;
源代码网推荐 begin
源代码网推荐 FDataSource.DataSet := FQuery;{ 该方法在查询结束后才调用 }
源代码网推荐 end;
源代码网推荐
源代码网推荐 procedure TThreadQuery.Execute;{ 执行线程的方法 }
源代码网推荐 begin
源代码网推荐 try
源代码网推荐 FQuery.Open; { 打开查询 }
源代码网推荐 Synchronize(ConnectDataSource);{ 线程同步 }
源代码网推荐 except
源代码网推荐 ShowMessage("Query Error"); { 线程异常 }
源代码网推荐 end;
源代码网推荐 end;
源代码网推荐
源代码网推荐 { 线程查询类的构造器 }
源代码网推荐 constructor TThreadQuery.Create(Query: TQuery; DataSource: TDataSource);
源代码网推荐 begin
源代码网推荐 FQuery := Query;
源代码网推荐 FDataSource := DataSource;
源代码网推荐 inherited Create(True);
源代码网推荐 FreeOnTerminate := False;
源代码网推荐 end;
源代码网推荐
源代码网推荐 { 创建窗体时创建线程查询对象 }
源代码网推荐 procedure TForm1.FormCreate(Sender: TObject);
源代码网推荐 begin
源代码网推荐 Q1 := TThreadQuery.Create(Query1, DataSource1);
源代码网推荐 Q2 := TThreadQuery.Create(Query2, DataSource2);
源代码网推荐 end;
源代码网推荐
源代码网推荐 { 销毁窗体时销毁线程查询对象 }
源代码网推荐 procedure TForm1.FormDestroy(Sender: TObject);
源代码网推荐 begin
源代码网推荐 Q1.Terminate; { 销毁之前终止线程执行 }
源代码网推荐 Q1.Destroy;
源代码网推荐 Q2.Terminate; { 销毁之前终止线程执行 }
源代码网推荐 Q2.Destroy;
源代码网推荐 end;
源代码网推荐
源代码网推荐 { 开始线程、继续执行线程、挂起线程 }
源代码网推荐 procedure TForm1.BtnGoPauseClick(Sender: TObject);
源代码网推荐 begin
源代码网推荐 if Q1.Suspended then Q1.Resume else Q1.Suspend;
源代码网推荐 if Q2.Suspended then Q2.Resume else Q2.Suspend;
源代码网推荐 end;
源代码网推荐
源代码网推荐 end.


源代码网推荐

源代码网供稿.
网友评论 (0)
会员中心
网络编程
本站推荐
网络编程之精华