新手問(DBGrid and combBox問題) |
尚未結案
|
diehuman
初階會員 發表:91 回覆:57 積分:29 註冊:2003-04-16 發送簡訊給我 |
|
chih
版主 發表:48 回覆:1186 積分:639 註冊:2002-04-02 發送簡訊給我 |
|
diehuman
初階會員 發表:91 回覆:57 積分:29 註冊:2003-04-16 發送簡訊給我 |
|
chih
版主 發表:48 回覆:1186 積分:639 註冊:2002-04-02 發送簡訊給我 |
|
Justmade
版主 發表:94 回覆:1934 積分:2030 註冊:2003-03-12 發送簡訊給我 |
這問題應與 dbgrid 無關 你使用 Locate 時,是一定要使用 DataSet 的欄位名稱(filed name)而不能使用 顯示名稱(displayLabel)的 所以,若你的 dataset 的欄位名稱是 MemberNo, 即使你在 DataSet 的 DisplayLabel, DBGrid 的 Title.Caption, 並 Combo Box 的 Lines 改成了 會員號碼 , Locate 時仍是要用 MemberNo 的 你可試試用以下方法解決 :
在Search Button 的 Click 時件設 :
[code]
var myfield : string;
begin
case comboBox.Itemindex of
0 : myfield := 'MemberNo'
1 : myfield := 'MemberName'
.....
end;
Locate(myfield,Edit1.Text,[loPartialKey,loCaseInsensitive]);
end;
|
diehuman
初階會員 發表:91 回覆:57 積分:29 註冊:2003-04-16 發送簡訊給我 |
|
wnhoo
高階會員 發表:75 回覆:443 積分:198 註冊:2003-04-22 發送簡訊給我 |
//根据DBGRID的TITLE动态产生DBCOMBOBX
procedure TForm1.DBComboBox1Enter(Sender: TObject);
VAR
I:INTEGER;
begin
DBComboBox1.Clear ;
FOR I:=0 TO DBGrid1.Columns.Count-1 DO
DBComboBox1.Items.Add(DBGrid1.Columns[I].Title.Caption);
IF DBComboBox1.Items.Count>0 THEN
DBComboBox1.ItemIndex :=0;
END; //查询
procedure TForm1.Button1Click(Sender: TObject);
begin TABLE1.Locate(TRIM(DBGrid1.Columns[DBComboBox1.ItemIndex].FieldName),
Edit1.Text,[loPartialKey,loCaseInsensitive]); end; 风花雪月 e梦情缘
------
风花雪月 e梦情缘 |
Mickey
版主 發表:77 回覆:1882 積分:1390 註冊:2002-12-11 發送簡訊給我 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |