[英]Calculating a ASPxGridview Column in DevExpress
我有一個ASPxGridview
(通常21列,但我只想處理4列)。
每列都有一個十進制值。 MV_EDDIE
空。
我想要的是,通過編程計算, MV_EDDIE
列僅在GroupSummary
和TotalSummary
是RISK_EUR - (IPOTEK + MV_BERND)
。
例如; 如果
RISK_EUR = 100
IPOTEK = 40
MV_BERND = 50
然后MV_EDDIE
欄應為100-(40 + 50)= 10
我怎樣才能做到這一點?
注意 :我有這樣的一個Sql
SELECT A.HESAP_NO, A.TEKLIF_NO1 || '/' || A.TEKLIF_NO2 AS TEKLIF,
A.MUS_K_ISIM, A.RISK,
(CASE WHEN A.DOVIZ_KOD = 21 THEN 'EUR' WHEN A.DOVIZ_KOD = 2 THEN 'USD' WHEN A.DOVIZ_KOD = 1 THEN 'TL' END) AS DOVIZ,
ROUND(KRISK_CV(A.TEKLIF_NO1, A.TEKLIF_NO2,A.DOVIZ_KOD,:TAR),2) AS RISK_EUR,
NVL(IPOTEK(A.HESAP_NO, :TAR),0) AS IPOTEK,
ROUND(SUM(M_V(A.TEKLIF_NO1, A.TEKLIF_NO2,:TAR)),2) AS MV_BERND,
ROUND(SUM(MV_EX(A.TEKLIF_NO1, A.TEKLIF_NO2,:TAR)),2) AS MV_EDDIE,
(CASE WHEN ROUND(SUM(MV_K(A.TEKLIF_NO1, A.TEKLIF_NO2,:TAR)),2) < 0 THEN
ROUND(SUM(MV_EX(A.TEKLIF_NO1, A.TEKLIF_NO2,:TAR)),2) ELSE
ROUND(SUM(MV_K(A.TEKLIF_NO1, A.TEKLIF_NO2,:TAR)),2) END) AS MV_KASKO,
B.TARIH, GGUNK(A.TEKLIF_NO1,A.TEKLIF_NO2,:TAR) AS GUN
FROM S_TEKLIF A, TMP_TAKIP B
WHERE A.HESAP_NO = B.HESAP
--AND A.HESAP_NO = 316
AND A.RISK > 0
GROUP BY B.TARIH, A.HESAP_NO, A.TEKLIF_NO1 || '/' || A.TEKLIF_NO2 ,
A.MUS_K_ISIM, GGUNK(A.TEKLIF_NO1,A.TEKLIF_NO2,:TAR),
A.RISK, A.DOVIZ_KOD,KRISK_CV(A.TEKLIF_NO1, A.TEKLIF_NO2,A.DOVIZ_KOD,:TAR)
ORDER BY 3
注2 :我可以解決此問題,更改我的sql查詢,但我不想要它。 我的查詢已經很復雜。 我不想改變它。 因此,我想以編程方式解決它..
編輯 :我只計算GroupSummary
和TotalSummary
。 沒有其他行。
如果有人考慮答案,我找到了。
protected void ASPxGridView1_Init(object sender, EventArgs e)
{
GridViewDataTextColumn colTotal = new GridViewDataTextColumn();
colTotal.Caption = "Total";
colTotal.FieldName = "Total";
colTotal.UnboundType = DevExpress.Data.UnboundColumnType.Decimal;
colTotal.VisibleIndex = ASPxGridView1.VisibleColumns.Count;
colTotal.PropertiesTextEdit.DisplayFormatString = "n0";
ASPxGridView1.Columns.Add(colTotal);
}
protected void ASPxGridView1_CustomUnboundColumnData(object sender, ASPxGridViewColumnDataEventArgs e)
{
if (e.Column.FieldName == "Total")
{
decimal risk = Convert.ToDecimal(e.GetListSourceFieldValue("RISK"));
decimal mv = Convert.ToDecimal(e.GetListSourceFieldValue("MV_BERND"));
decimal ipotek = Convert.ToDecimal(e.GetListSourceFieldValue("IPOTEK"));
e.Value = risk - mv - ipotek;
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.