線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:1096
推到 Plurk!
推到 Facebook!

DBGrid 改變顯示資料

尚未結案
unisabilly
一般會員


發表:19
回覆:20
積分:17
註冊:2004-05-20

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-01-03 00:03:44 IP:168.209.xxx.xxx 未訂閱
各位大大新年快樂, 小弟有一個問題,小弟是用Query -> DataSource -> DBGrid 把資料庫的的東西抓到DBGrid上面 而資料庫裡某一欄是用代碼來記錄的,例如說Error這一欄裡顯示的都是代碼,c 代表connection error,s 代表success等等,請問一下我該如何做才能讓DBGrid裡面顯示整個錯誤(connection error)而不是代碼(c). ~~ 新手上路.衝.衝.衝.
shinjie
資深會員


發表:12
回覆:275
積分:287
註冊:2003-03-19

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-01-03 08:05:59 IP:203.73.xxx.xxx 未訂閱
在Query的OnCalcFields裡面加入以下程式碼 if DataSet.FieldByName('ERROR').AsString='c' then DataSet.FieldByName('ERROR').AsString='connection error'; if DataSet.FieldByName('ERROR').AsString='s' then DataSet.FieldByName('ERROR').AsString='success';
------
我將在茫茫人海中尋訪我唯一之靈魂伴侶。
得之;我幸。不得;我命。
pigbaby
初階會員


發表:2
回覆:84
積分:47
註冊:2002-09-02

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-01-03 08:28:50 IP:210.200.xxx.xxx 未訂閱
建議利用SQL 語法去解決  豬寶寶的範例是 在A有USER的詳細DATA B是GROUP的資料 而這個指令可以從A的GROUP_ID到B 內把GROUP的描述取出來 以A的GROUP_ID 跟B的KEY比對 
select a.name, b.group_DESC from USER_DATA A, USER_GROUP B WHERE A.GROUP_ID = B.GROUP_ID
deity
尊榮會員


發表:90
回覆:876
積分:678
註冊:2003-05-09

發送簡訊給我
#4 引用回覆 回覆 發表時間:2005-01-03 11:23:19 IP:218.15.xxx.xxx 未訂閱
引言: 各位大大新年快樂, 小弟有一個問題,小弟是用Query -> DataSource -> DBGrid 把資料庫的的東西抓到DBGrid上面 而資料庫裡某一欄是用代碼來記錄的,例如說Error這一欄裡顯示的都是代碼,c 代表connection error,s 代表success等等,請問一下我該如何做才能讓DBGrid裡面顯示整個錯誤(connection error)而不是代碼(c). ~~ 新手上路.衝.衝.衝.
unisabilly 您好: 您的意思是想将Error這一欄裡的c 在DBGrid里显示为connection error,s在DBGrid里显示为success?是的话可参考下列二种方法
procedure TForm1.DBGrid1DrawColumnCell(Sender: TObject; const Rect: TRect;
  DataCol: Integer; Column: TColumn; State: TGridDrawState);
Var
  Str : String;
begin
  if SameText(Column.FieldName, 'Error') then
    begin  
      Str := '';
      if Column.Field.AsString = 'c' then
        Str := 'connection error'
      else
      if Column.Field.AsString = 's' then
        Str := 'success';
      if Str <> '' then
        begin
          DBGrid1.Canvas.TextRect(Rect, Rect.Left 2, Rect.Top 2, Str);
        end;
    end;
end;
方法二:
首先Add All fields 加入所有字段。
然后下下列代码:
procedure TForm1.Query1ErrorGetText(Sender: TField; var Text: String;
  DisplayText: Boolean);
begin
  if Query1Error.value = 'c' then
    text := 'connection error';
  if Query1Error.value = 's' then
    text := 'success'; 
end;
 
试试看 <>~~~静心养德~~~ 發表人 -
pillar62
資深會員


發表:9
回覆:324
積分:271
註冊:2002-04-15

發送簡訊給我
#5 引用回覆 回覆 發表時間:2005-01-03 17:13:18 IP:210.64.xxx.xxx 未訂閱
也可以在欄位的OnSetText的事件裡面作處理 例如 if field('').value = 'c' then text := 'connection error' else text := ''; Pillar Wang
------
Pillar Wang
系統時間:2024-06-26 9:06:45
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!