怎樣去改變DBGrid的某一列的值
請教大家一個問題
怎樣去改變DBGrid的某一列的值,但數據庫本身數據不改變,只在DBGrid中改變該字段就行?
[解决办法]
数据改变之后当记录指针移动的时候,改变会自动更新到数据库里.单单只为满足这点需求的话,可以考虑改用其他的Grid控件比如StringGrid.
[解决办法]
选择DBGRID,找到事件 “DrawColumnCell”
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); }}