如何将dbgrid中某栏的值求和 |
尚未結案
|
zwsoft
一般會員 發表:20 回覆:17 積分:10 註冊:2002-11-18 發送簡訊給我 |
|
Justmade
版主 發表:94 回覆:1934 積分:2030 註冊:2003-03-12 發送簡訊給我 |
若你不介意使用 ClientDataSet 的話,可以改成 : TQuery->TDataSetProvider->TClientDataSet->TDataSources->TDBGrid
那你便可以使用 Aggregate Field 來計算欄位的總值等等。 參考 :
ClientDataSet 簡單範例
http://delphi.ktop.com.tw/topic.php?TOPIC_ID=28513
http://delphi.ktop.com.tw/topic.php?TOPIC_ID=30526 其實還可作分組加總 :
http://delphi.ktop.com.tw/topic.php?TOPIC_ID=33087 使用 ClientDataSet 要注意 :
1. 分發時要分發 MIDAS.DLL
2. 要 ApplyUpdate(0)才真的儲存數據庫。
|
zwsoft
一般會員 發表:20 回覆:17 積分:10 註冊:2002-11-18 發送簡訊給我 |
|
channel
尊榮會員 發表:67 回覆:707 積分:854 註冊:2002-05-02 發送簡訊給我 |
引言: 可是我用的是adoquery呀.那该怎么办?提供一個方法:在AfterPost事件取得合計 procedure TForm1.ADOQuery1AfterPost(DataSet: TDataSet); var qrySum: TADOQuery; aSum: Integer; begin qrySum := TADOQuery.Create(nil); try qrySum.ConnectionString := ADOConnection1; qrySum.Close; qrySum.Connection := ''; qrySum.Connection := 'Select Sum(FieldName) SumField From TableName Where ....' qrySum.Open; aSum := qrySum.FieldByName('SumField').AsInteger;//取得合計 finally qrySum.Free; end; end;~小弟淺見,參考看看~
------
~小弟淺見,參考看看~ |
chih
版主 發表:48 回覆:1186 積分:639 註冊:2002-04-02 發送簡訊給我 |
引言: 可是我用的是adoquery呀.那该怎么办? 貼一段我的做法給你參考看看...在adoqueryafterpost事件... procedure TForm1.adoquery1AfterPost(DataSet: TDataSet); var Lock_Record: TBookMark; WTOTAL_PRICE: REAL; begin Lock_Record := adoquery1.GetBookMark; adoquery1.DisableControls; adoquery1.first; WTOTAL_PRICE:= 0; while not adoquery1.eof do begin //加總DBGRID的金額 WTOTAL_PRICE := WTOTAL_PRICE adoquery1PRICE.Value; adoquery1.Next; end; adoquery1.first; adoquery1.EnableControls; Edit1.Text := floattostr(WTOTAL_PRICE);//加總的金額 adoquery1.FreeBookMark(Lock_Record); end;TRY TRY SEE |
danielldf
一般會員 發表:44 回覆:60 積分:20 註冊:2003-05-12 發送簡訊給我 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |