全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:836
推到 Plurk!
推到 Facebook!

(Delphi6)请教各位大侠一个 DBGrid的问题(急盼回复)

尚未結案
shaohong99
一般會員


發表:3
回覆:0
積分:0
註冊:2004-12-22

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-01-19 16:57:09 IP:202.103.xxx.xxx 未訂閱
我的数据库中有一些数据为0, 如何能使这些为0的数字 在DBGrid中不显示出来? 急盼回复,在这先谢谢各位大侠了!!!
Fishman
尊榮會員


發表:120
回覆:1949
積分:2163
註冊:2006-10-28

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-01-19 17:06:15 IP:210.65.xxx.xxx 未訂閱
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

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-01-19 18:42:10 IP:202.62.xxx.xxx 未訂閱
您好﹗    您可使用在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;
================================= 有空來瞅瞅我﹗因為我是您的朋友﹐有您真好﹗ ================================
------
忻晟
系統時間:2024-05-13 3:17:56
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!