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

關淤TclientDataSet 的Aggregates

答題得分者是:l630521
guochunlin
一般會員


發表:19
回覆:8
積分:5
註冊:2005-07-21

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-11-09 14:59:59 IP:219.132.xxx.xxx 未訂閱
我在用主從表時,對從表的某一欄位進行匯總,我是這樣的: 給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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-11-09 17:14:41 IP:203.73.xxx.xxx 未訂閱
請問你是不是用TDataSetField來做關聯,如果是的話,Delphi會把關聯你Master資料表的所有Detail資料都抓進來你的DetailDataSet,而Aggregate會把你DetailDataSet的所有資料做計算,不會針對你的過濾條件做計算,所以你看到的欄位值是你所有DetailDataSet的SUM值,你可以試看看,所以我在這一方面都是自己計算的! Ian
guochunlin
一般會員


發表:19
回覆:8
積分:5
註冊:2005-07-21

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-11-09 19:03:09 IP:219.132.xxx.xxx 未訂閱
我是把DetailDataSet的MasterSource設置爲MainDatasource,MasterFields與MainlDataSet關聯的,應該不要自己計算吧。我想我肯定有地方沒有設置好.
guochunlin
一般會員


發表:19
回覆:8
積分:5
註冊:2005-07-21

發送簡訊給我
#4 引用回覆 回覆 發表時間:2005-11-09 20:28:12 IP:219.132.xxx.xxx 未訂閱
難道ClientDataSet的主從表設置錯了?ClientDataSet的主從表如何設置?
l630521
資深會員


發表:15
回覆:349
積分:372
註冊:2003-02-17

發送簡訊給我
#5 引用回覆 回覆 發表時間:2005-11-10 08:15:48 IP:211.74.xxx.xxx 未訂閱
我的意思是除非你的DetailDataSet只有取得鍵值等於表頭的明細資料,不然Aggregate是會把符合你表頭資料的所有明細一起加進來計算,不會只計算你當筆表頭的資料,你可以試試把符合你表頭所下條件的明細全部加總起來,應該就是你現在看到的計算結果,例: Master : select * from MasterTable where P1 in ('123', '456') 如果用Delphi的TDataSetField的方式,應該會把Detal的鍵值等於'123'、'456'的資料都抓進來,也就是說你現在看到的Detail加總的計算會是包含'123'、'456'這兩筆主鍵值的所有明細資料,你可以試看看! 如果你是一次只取得'123'的資料,那我的說法就不成立了! Ian
系統時間:2024-06-27 0:02:43
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!