線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:1599
推到 Plurk!
推到 Facebook!

怎样停止ADOQuery的查询

尚未結案
hatcolorKTop
一般會員


發表:1
回覆:0
積分:0
註冊:2004-07-11

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-07-11 12:31:23 IP:219.137.xxx.xxx 未訂閱
由于数据库比较庞大,所以查询时间比较长,有否方法停止正在查询的动作
Chance36
版主


發表:31
回覆:1033
積分:792
註冊:2002-12-31

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-07-11 23:33:35 IP:203.204.xxx.xxx 未訂閱
引言: 由于数据库比较庞大,所以查询时间比较长,有否方法停止正在查询的动作
hatcolorKTop 你好 為了在查詢過程當中,可以停止查詢的動作,你必須將AdoQuery.ExecuteOptions 包含[eoAsyncFetchNonBlocking]非同方式來查詢資料,當你將AdoQuery設為非同步方式時,有兩個事件要注意的, 1.OnFetchComplete : 動作完成時會觸發此事件,告訢使用者查詢已完成了 2.OnFetchProgress : 查詢動件進行中,隨時會觸發,你可以在此事件中做些判斷並顯示目前查詢的進度比例 因此要能夠中止查詢的動作,只要在OnFetchProgress事件中設定其參數var EventStatus: TEventStatus;設為 esCancel 就可以了。以下判斷進度超過一半即行中止。
procedure TForm1.ADOQuery1FetchProgress(DataSet: TCustomADODataSet;
  Progress, MaxProgress: Integer; var EventStatus: TEventStatus);
begin
  ProgressBar1.Max := MaxProgress ;
  ProgressBar1.Position := Progress;
  If (Progress/MaxProgress) > 0.5 Then
    EventStatus := esCancel ;
end;
Ktop_Robot
站務副站長


發表:0
回覆:3511
積分:0
註冊:2007-04-17

發送簡訊給我
#3 引用回覆 回覆 發表時間:2007-04-30 13:44:49 IP:000.000.xxx.xxx 未訂閱
提問者您好:


以上回應是否已得到滿意的答覆?


若已得到滿意的答覆,請在一週內結案,否則請在一週內回覆還有什麼未盡事宜,不然,
將由版主(尚無版主之區域將由副站長或站長)自由心證,選擇較合適之解答予以結案處理,
被選上之答題者同樣會有加分獎勵同時發問者將受到扣 1 分的處分。不便之處,請見諒。


有問有答有結案,才能有良性的互動,良好的討論環境需要大家共同維護,感謝您的配合。

------
我是機器人,我不接受簡訊.
系統時間:2024-04-19 11:06:30
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!