(Delphi6)请教各位大侠一个 DBGrid的问题(急盼回复) |
尚未結案
|
shaohong99
一般會員 發表:3 回覆:0 積分:0 註冊:2004-12-22 發送簡訊給我 |
|
Fishman
尊榮會員 發表:120 回覆:1949 積分:2163 註冊:2006-10-28 發送簡訊給我 |
Hi shaohong99, 使用 Filter 或是 OnFilterRecord 事件中過濾,甚至於 SQL Command 中就過濾掉也可以 1.Filter
procedure TForm1.Button1Click(Sender: TObject); begin Query1.Close; Query1.Open; Query1.Filtered := False; Query1.Filter := 'FloatFieldName <> 0'; Query1.Filtered := True; end;2.OnFilterRecord Set Query1.Filtered to True and add below code to Query's OnFilterRecord Event procedure TForm1.Query1FilterRecord(DataSet: TDataSet; var Accept: Boolean); begin if Dataset.FieldByName('FloatFieldName').AsFloat = 0 then Accept := False else Accept := true; end;3.SQL Command select * from yourtable where floatfieldname <> 0發表人 -
------
Fishman |
cashxin2002
版主 發表:231 回覆:2555 積分:1937 註冊:2003-03-28 發送簡訊給我 |
您好﹗ 您可使用在DBGrid的OnDrawColumnCell事件中重繪DBGrid的方法﹐將某欄位值為0的不做顯示﹐方法如下﹕
Var CellStr : String; begin CellStr := ''; if SameText(Culumn.FieldName, '欄位名稱') then // 欄位名稱處填入相對應的欄位名稱﹐如果有多欄位的話﹐也可使用 // Or語法統一再對其進行判斷 begin if Column.Field.Value = 0 then DBGrid1.Canvas.TextRect(Rect, Rect.Left+2, Rect.Top+2, CellStr); end; end;================================= 有空來瞅瞅我﹗因為我是您的朋友﹐有您真好﹗ ================================
------
忻晟 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |