效能最佳化之報表與演算法的統一管理
在報表專案中,常常有些複雜的資料計算是一個報表專門使用的,其它報表用不到。通常,此類計算可以在報表資料來源中用 SQL 實現,不過由於 SQL 無法分步計算,需要寫非常複雜難懂的長語句,不利於除錯和維護,因此也會使用 Java 或者儲存過程來實現。但這樣一來,計算程式又會和報表模板分開,不利於組織管理。
使用潤乾報表的指令碼資料集(結合集算器實現)來實現報表專用計算,是解決上述困境的一個有效手段,一方面既可以寫出簡單易懂的分步計算指令碼,另一方面又可以將指令碼和報表模板一起存放,利於管理。
這兩種方式的系統結構對比如下圖所示:
下面透過一個具體的報表例子來看一下潤乾報表指令碼資料集的用法。
下表是一個《年度客戶銷售分析報表》,要求可以選擇年份作為輸入引數:
其中,CLIENT 是客戶,TOTAL 是客戶銷售總額,DATE1 是客戶最後一次銷售日期,AMOUNT1 是客戶最後一次銷售金額,DATE2 是客戶倒數第二次銷售日期,AMOUNT2 是客戶倒數第二次銷售日期。
1、定義報表引數
在潤乾報表中新建報表模板後,要定義報表引數:
2、配置指令碼資料集
定義一個指令碼資料集如下:
指令碼資料集編寫如下:
A | B | |
---|---|---|
1 | =create(client,total,date1,amount1,date2,amount2) |
|
2 | =demo.query(“select * from sales where year(ORDERDATE)=”+year) |
|
3 | =A2.group(CLIENT) |
|
4 | for A3 |
|
5 |
|
>client=A4.m(1).CLIENT |
6 |
|
>total=A4.sum(AMOUNT) |
7 |
|
=A4.sort(ORDERDATE:-1) |
8 |
|
>date1=B6.m(1).ORDERDATE |
9 |
|
>amount1=B6.m(1).AMOUNT |
10 |
|
>date2=B6.m(2).ORDERDATE |
11 |
|
>amount2=B6.m(2).AMOUNT |
12 | result A1 |
|
程式碼說明:
A1:新建一個空序表,準備存放結果資料。
A2:使用報表的資料來源 demo 用簡單的 sql 取出銷售資料,year 是報表的引數。
A3:對銷售資料按照 CLIENT 分組。
A4:開始對分組資料迴圈處理。
B4:-B11:求結果資料,插入 A1 中,這裡不再詳細介紹。
A12:將結果資料 A1 返回給報表。
3、報表設計
回到報表設計器主介面,報表設計如下圖:
儲存為 salary.rpx 即可。可以看到報表設計、計算指令碼編寫都在同一個 rpx 檔案中,管理變得簡單。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69900830/viewspace-2667688/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 實現報表與演算法的統一管理演算法
- 報表的效能最佳化
- 效能最佳化之報表資料預先計算
- 效能最佳化指南:效能最佳化的一般性原則與方法
- 大資料交叉報表效能最佳化案例(方案)大資料
- oracle大表效能最佳化Oracle
- 如何最佳化 RAG 系統的效能表現?10 條實用策略
- 最佳化系統效能:同步與非同步操作的巧妙平衡非同步
- SQL效能最佳化之索引最佳化法SQL索引
- Sql最佳化之回表SQL
- MYSQL效能最佳化分享(分庫分表)MySql
- 報表工具對比之潤乾報表與銳浪報表對比
- Android 效能最佳化之執行緒Android執行緒
- Oracle最佳化之單表分頁最佳化Oracle
- babel-polyfill使用與效能最佳化Babel
- cssProcessor.process(css.source, processOptions, 報錯(css壓縮之效能最佳化)CSS
- WPF效能最佳化之UI虛擬化UI
- VUE系列之效能最佳化--懶載入Vue
- 效能最佳化的一般策略及方法
- Oracle 效能最佳化之核心的shmall 和shmmax 引數OracleHMM
- OA軟體之報表與統計,快速掌握各崗位工作流程
- elasticsearch演算法之推薦系統的相似度演算法(一)Elasticsearch演算法
- 前端效能最佳化實踐方向與方法前端
- 安卓效能最佳化—使用ArrayMap與SparseArray安卓
- redis georadius原始碼分析與效能最佳化Redis原始碼
- 如何分析報表效能問題
- 如何最佳化大模型在Java環境下的效能表現大模型Java
- Android系統資源管理與電池最佳化策略詳解Android
- 最佳化系統效能:深入探討Web層快取與Redis應用的挑戰與對策Web快取Redis
- PHP開發規範之效能最佳化分享PHP
- Android效能最佳化之記憶體洩露Android記憶體洩露
- Flutter 統一彈窗管理的思考與實現Flutter
- 微課sql最佳化(12)、表的連線方法(1)-幫助網友最佳化報表SQLSQL
- 資料結構與演算法(一):線性表資料結構演算法
- vivo統一接入閘道器VUA轉發效能最佳化實踐
- MySQL最佳化之系統變數最佳化MySql變數
- 後臺管理系統之詳解(一)
- 微課sql最佳化(4)、幫助“表姐”最佳化報表SQL