怎樣去改變DBGrid的某一列的值,该如何处理

怎樣去改變DBGrid的某一列的值
請教大家一個問題
怎樣去改變DBGrid的某一列的值,但數據庫本身數據不改變,只在DBGrid中改變該字段就行?

------解决方案--------------------
数据改变之后当记录指针移动的时候,改变会自动更新到数据库里.单单只为满足这点需求的话,可以考虑改用其他的Grid控件比如StringGrid.
------解决方案--------------------
选择DBGRID,找到事件 “DrawColumnCell”

C/C++ code


void __fastcall TfrmSets::dbGridDrawColumnCell(TObject *Sender,
      const TRect &Rect, int DataCol, TbsColumn *Column,
      TGridDrawState State)
{
    if(Column->FieldName=="預定差额") //当列的名称(字段名)为:"預定差额" 的时候 
    {
        //下面代码的作用,是改变所有数值的正负号,你可以你的需求,修改这一列的值,不会修改到数据库里面的数据
        int iLeft,iTop;
        AnsiString strText;
        strText=strText.FormatFloat("0.00",-Column->Field->AsFloat);
        iLeft=Rect.Left+(Rect.Width() -((TbsSkinDBGrid *)Sender)->Canvas->TextWidth(strText))/2;
        iTop=Rect.Top+(Rect.Height() -((TbsSkinDBGrid *)Sender)->Canvas->TextHeight(strText))/2;
        ((TbsSkinDBGrid *)Sender)->Canvas->TextRect(Rect,iLeft,iTop,strText);
    }
}