關淤TclientDataSet 的Aggregates |
答題得分者是:l630521
|
guochunlin
一般會員 發表:19 回覆:8 積分:5 註冊:2005-07-21 發送簡訊給我 |
我在用主從表時,對從表的某一欄位進行匯總,我是這樣的:
給DetailDataSet加Aggregate欄位
設定 DetailDataSet.AggeratesActive := True;
設定
Aggregate.Active := False;
Aggregate.Expression := 'Sum(Field)'; // 或是 Max(Field)
Aggregate.Active := True;
就可以用 Aggregate.Value 來取得 Sum.
但是問題來了,我移動主表記錄(當然從表也會變),SUM的值就是不變?一直找不到原因?
|
l630521
資深會員 發表:15 回覆:349 積分:372 註冊:2003-02-17 發送簡訊給我 |
|
guochunlin
一般會員 發表:19 回覆:8 積分:5 註冊:2005-07-21 發送簡訊給我 |
|
guochunlin
一般會員 發表:19 回覆:8 積分:5 註冊:2005-07-21 發送簡訊給我 |
|
l630521
資深會員 發表:15 回覆:349 積分:372 註冊:2003-02-17 發送簡訊給我 |
我的意思是除非你的DetailDataSet只有取得鍵值等於表頭的明細資料,不然Aggregate是會把符合你表頭資料的所有明細一起加進來計算,不會只計算你當筆表頭的資料,你可以試試把符合你表頭所下條件的明細全部加總起來,應該就是你現在看到的計算結果,例:
Master : select * from MasterTable where P1 in ('123', '456')
如果用Delphi的TDataSetField的方式,應該會把Detal的鍵值等於'123'、'456'的資料都抓進來,也就是說你現在看到的Detail加總的計算會是包含'123'、'456'這兩筆主鍵值的所有明細資料,你可以試看看!
如果你是一次只取得'123'的資料,那我的說法就不成立了! Ian
|
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |