dbgrid中如何选择要显示那些行? |
答題得分者是:Chance36
|
ffprince
初階會員 發表:66 回覆:62 積分:25 註冊:2003-08-16 發送簡訊給我 |
|
terrychen
尊榮會員 發表:90 回覆:794 積分:501 註冊:2003-05-01 發送簡訊給我 |
|
ffprince
初階會員 發表:66 回覆:62 積分:25 註冊:2003-08-16 發送簡訊給我 |
|
terrychen
尊榮會員 發表:90 回覆:794 積分:501 註冊:2003-05-01 發送簡訊給我 |
|
Chance36
版主 發表:31 回覆:1033 積分:792 註冊:2002-12-31 發送簡訊給我 |
引言: 可我要判断的东西太复杂,所以想不出asl语句怎么写 // 1..在 dbGrid->DataSource->DataSet(假設為Table1) 的OnFilterRecord 事件中撰寫 // procedure TForm1.Table1FilterRecord(DataSet: TDataSet; var Accept: Boolean); begin //條件判斷 理論上任何的程式碼皆可接受,但要注意 絕對不可動到DataSet的記錄指標 .... .... // 因為每筆記錄皆會觸發此事作, // 最後給作用中的記錄一個結果 (接受或不接受) If (要顯示) Then Accept := True Else Accept := False; end; // 2..在需要過濾的時候將過濾功能打開 Tale1.Filted := True; |
ffprince
初階會員 發表:66 回覆:62 積分:25 註冊:2003-08-16 發送簡訊給我 |
引言:多谢,我马上试试。但我要如何提取tabel中的数据来做判断条件?// 1..在 dbGrid->DataSource->DataSet(假設為Table1) 的OnFilterRecord 事件中撰寫 // procedure TForm1.Table1FilterRecord(DataSet: TDataSet; var Accept: Boolean); begin //條件判斷 理論上任何的程式碼皆可接受,但要注意 絕對不可動到DataSet的記錄指標 .... .... // 因為每筆記錄皆會觸發此事作, // 最後給作用中的記錄一個結果 (接受或不接受) If (要顯示) Then Accept := True Else Accept := False; end; // 2..在需要過濾的時候將過濾功能打開 Tale1.Filted := True; |
Chance36
版主 發表:31 回覆:1033 積分:792 註冊:2002-12-31 發送簡訊給我 |
|
ffprince
初階會員 發表:66 回覆:62 積分:25 註冊:2003-08-16 發送簡訊給我 |
|
Chance36
版主 發表:31 回覆:1033 積分:792 註冊:2002-12-31 發送簡訊給我 |
|
ffprince
初階會員 發表:66 回覆:62 積分:25 註冊:2003-08-16 發送簡訊給我 |
|
Chance36
版主 發表:31 回覆:1033 積分:792 註冊:2002-12-31 發送簡訊給我 |
假設 AdoQuery1已開啟一些資料錄 AdoQuery1.Close; AdoQuery1.Filtered; // 記得要先設為 False; AdoQuery1.SQL.Clear; AdoQuery1.SQL.Add('Select * From SomeTable'); AdoQuery1.SQL.Add('Where Field1=''SomeValue'' '); AdoQuery1.Open; // 如果有需要一開啟就過濾則加以下指令 AdoQuery1.Filtered := True; // 1..在OnFilterRecord 事件中撰寫 // procedure TForm1.AdoQuery1FilterRecord(DataSet: TDataSet; var Accept: Boolean); begin // 姓'王' 且年齡大於等於30 者 才會顯示 其他則隱藏 If (DataSet.FieldByName('Age').AsInteger >= 30) And (Copy(DataSet.FieldByName('Name').AsString,1,2)= '王') Then Accept := True // 接受(會顯示) Else Accept := False;// 不接受(不會顯示) end; // 2..在需要過濾的時候將過濾功能打開 例如在按了某個按鈕後才需過濾,則在該按鈕的OnClick事件中加入下列指令 Procedure TForm1.Button1Click(Sender:TObject); Begin AdoQuery1.Filtered := True;//開啟功能 或 AdoQuery1.Filtered := Not AdoQuery1.Filtered; //切換功能 End; |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |