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

如何将dbgrid中某栏的值求和

尚未結案
zwsoft
一般會員


發表:20
回覆:17
積分:10
註冊:2002-11-18

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-07-01 15:32:05 IP:218.17.xxx.xxx 未訂閱
dbgrid连上的是一个query,并且dbgrid中的数据是新增上去的。
Justmade
版主


發表:94
回覆:1934
積分:2030
註冊:2003-03-12

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-07-01 15:54:14 IP:218.16.xxx.xxx 未訂閱
若你不介意使用 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

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-07-01 16:01:58 IP:218.17.xxx.xxx 未訂閱
可是我用的是adoquery呀.那该怎么办?
channel
尊榮會員


發表:67
回覆:707
積分:854
註冊:2002-05-02

發送簡訊給我
#4 引用回覆 回覆 發表時間:2003-07-01 17:56:48 IP:211.21.xxx.xxx 未訂閱
引言: 可是我用的是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

發送簡訊給我
#5 引用回覆 回覆 發表時間:2003-07-02 15:08:03 IP:210.241.xxx.xxx 未訂閱
引言: 可是我用的是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

發送簡訊給我
#6 引用回覆 回覆 發表時間:2003-10-09 15:09:37 IP:218.16.xxx.xxx 未訂閱
謝謝chih,我也用到了.這樣做似乎比cds簡單一點.
系統時間:2024-06-02 13:49:47
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!