溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

BIRT交叉表中自由格間運算如何做

發布時間:2022-01-15 15:16:14 來源:億速云 閱讀:115 作者:柒染 欄目:大數據

BIRT交叉表中自由格間運算如何做,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

比如要處理這么個場景:

1、根據明細記錄完成交叉表。

2、在交叉表上統計每行的小計(中間過程)。

3、計算交叉表中每個值占小計的百分比。

計算流程如下圖所示:

BIRT交叉表中自由格間運算如何做

BIRT等工具都會提供一些計算列的功能,可以在原始數據基礎上再計算出一些別的列值或統計值,所以很容易實現前面2步。但由于傳統工具(包含BIRT)沒有很好的運算后報表數據項命名機制(一般用列名命名設計階段的數據單元),很難精確描述數據引用關系,只能寫出規律性很強的表達式,而隨意的獨立格運算就使傳統工具難以處理。

常見的解決辦法就是寫自定義數據集(復雜SQL或scripted data sources),把數據事先計算好后再塞入到報表格子中。但自定義數據集方式,代碼非常麻煩,工作量大。

如果使用集算器則會簡單很多,其豐富的集合運算可以方便地完成這類計算,比scripted data sources代碼要短,比SQL寫起來更簡單,比如類似的計算在集算器里可以這樣寫:


A

1

=myDB.query@x("select * from record")

2

=A1.pivot(time;department,count)

3

>A2.run(t=Admin+Finance+Management,Admin=string(Admin/t,"0.00%"),Finance=string(Finance/t,"0.00%"),Management=string(Management/t,"0.00%"))

4

return A2

其實還有很多類似的計算問題在BIRT中處理不太方便,但有集算器SPL的輔助卻很簡單。

集算器提供了JDBC驅動,可以很方便的與BIRT等報表工具集成, BIRT調用SPL腳本有使用和獲得它的方法。

看完上述內容,你們掌握BIRT交叉表中自由格間運算如何做的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女