怎样停止ADOQuery的查询 |
尚未結案
|
hatcolorKTop
一般會員 發表:1 回覆:0 積分:0 註冊:2004-07-11 發送簡訊給我 |
|
Chance36
版主 發表:31 回覆:1033 積分:792 註冊:2002-12-31 發送簡訊給我 |
引言: 由于数据库比较庞大,所以查询时间比较长,有否方法停止正在查询的动作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 發送簡訊給我 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |