報表如何實現行列互換效果?
通常我們設計的二維的交叉報表,橫向的維度和縱向的維度是固定的,而使用者希望更希望能根據自己的需要快速轉換橫向縱向維度來檢視報表。
如上圖所示,我們透過點選一個按鈕或文字,就可將報表的行列維度互相轉換,這樣的動態轉換效果要怎麼設定實現呢?
這裡我介紹兩種方法實現方法:
1. 兩張報表超連結
2. 單張報表動態判斷
兩張報表超連結
實現思路:
二維的交叉報表行列維度有兩種情況,我們只需對應兩種情況做兩張報表,切換的按鈕用超連結實現,連線的目標就是另一張報表。
具體實現:
1. 新建一張報表,檔名為行列轉換 1.rpx, 資料來源使用潤乾設計器下自帶的 demo 資料來源,資料集使用 SQL 檢索方式,SQL 為:SELECT 訂單. 貨主地區, 訂單. 訂單金額, 僱員. 姓氏 + 僱員. 名字 as 僱員 FROM 訂單, 僱員 WHERE 訂單. 僱員 ID = 僱員. 僱員 ID 。
2. 設定報表單元格表示式,潤乾設計器中單元格可以直接寫表示式,也支援拖拽欄位生成表示式。
B1 單元格我們透過拖拽欄位的方式生成表示式:在設計器右下角的資料集皮膚中可以看到我們剛才新建的資料集和欄位,選擇對應欄位,然後選擇分組,將欄位拖拽到 B1 單元格中,
B1 單元格就會出現 =ds1.group(貨主地區; 貨主地區);
A2 單元格同 B1 的操作,不同的是選擇僱員欄位拖拽,生成的表示式為 =ds1.group(僱員; 僱員:1);
B2 單元格選擇訂單金額,選擇彙總,彙總方式為求和,拖拽欄位到 B2 單元格中,表示式為 =ds1.sum(訂單金額)。
3. 修改單元格擴充套件方式,單元格的擴充套件方向預設為縱向,選中 B1,在右側屬性皮膚中設定擴充套件方式為橫向擴充套件。
4.A1 單元格中直接寫上行列互換,設定超連結表示式:“./showReport.jsp?rpx=/30 互動報表 / 行列互換 2.rpx”,超連結視窗為:_self。
5. 將當前報表另存一張,儲存檔名為“行列轉換 2.rpx”,將 B1 和 A2 單元格表示式對調,將 A1 的超連結表示式修改為:“./showReport.jsp?rpx=/30 互動報表 / 行列互換 1.rpx”。
經過以上設定,我們就完成了最不燒腦的二維報表行列互換報表的製作,使用 showReport.jsp 訪問行列轉換 1.rpx,點選行列轉換那幾個字就會變成行列轉換 2.rpx,使用者儘管點選切換,不用做條件判斷。
單張報表動態判斷
實現思路:
根據標誌 flag 當前值,來改變他的值,根據這個值確定橫向分組和縱向分組使用的欄位。
具體實現
1. 將行列轉換 1.rpx 另存一個報表,檔名為行列轉換.rpx。
2. 報表中增加一個普通引數,引數名稱為 change, 資料型別為整數,預設的引數值為 1;
兩個動態引數:引數名稱 group1, 資料型別為字串,值表示式為 if(change==1,“貨主地區”,“僱員”;
引數名稱 Group2, 資料型別為字串,值表示式為 if(change==1,“僱員”,“貨主地區”)。
3. 修改單元格表示式
橫向分組和縱向分組的欄位透過動態引數的值,動態變化,將 B1 的表示式修改為 =ds1.group(${group1};${group1}:1),將 A2 的表示式修改為 =ds1.group(${group2};${group2}:1)。
4. 修改行列互換的超連結表示式
超連結表示式為:“./showReport.jsp?rpx=/30 互動報表 / 行列互換.rpx&change=”+if(change==1,-1,1)
經過以上設定,我們透過 showReport.jsp 訪問行列轉換.rpx, 在瀏覽器位址列中,輸入 url:
訪問。
當點選表頭中的行列轉換文字,重新整理的報表還是當前的報表,但 change 的引數值已經變成了 -1,並且行列的分組欄位也發生了變化。
透過上面介紹的兩種方法都能快速的實現報表行列互換的效果,如果不想做多張報表來實現,推薦使用第二種實現方法,如果不習慣條件判斷的設定,可以使用第一種方法,雖然涉及到兩張報表,只是另存第一張報表,簡單修改就行,修改的工作量可忽律不計,也沒有第二種方法的小彎彎繞,具體根據自己的情況選擇合適的方法吧。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69900830/viewspace-2669014/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- web 展現資料時如何實現行列互換Web
- 在報表中錄入資料時如何實現行列轉換
- 實現二維陣列的行列互換陣列
- sql 實現表的行列轉換SQL
- 在Word中實現表格的行列互換 (轉)
- 報表展現時如何實現固定表頭效果
- SQL Server 實現行列(縱橫表)轉換SQLServer
- Oracle行列互換總結Oracle
- oracle 行列互換總結Oracle
- sqlserver 行列互轉實現小結SQLServer
- 大屏報表元件間的聯動互動效果實現方法元件
- pivot、unpivot實現oracle行列轉換Oracle
- 在SQL Server 2005中實現表的行列轉換SQLServer
- 用abap實現內表的行列轉換-原始碼2 (轉)原始碼
- 行列轉換 交叉表 (轉)
- [轉]decode函式和行列互換函式
- Spark實現行列轉換pivot和unpivotSpark
- 「譯」如何實現互動式 WebGL 懸停效果Web
- 填報表實現隔行異色的效果
- sql語句實現表的行列倒置SQL
- 用ORACLE分析函式實現行列轉換Oracle函式
- 如何實現報表滾動到底部進行翻頁的效果
- web 端展現報表資料時如何實現摺疊展開效果?Web
- 實現報表滾動到底部翻頁效果
- 使用vue實現行列轉換的一種方法。Vue
- WORD及EXCEL行列轉換實現方法收藏(轉)Excel
- 報表中怎樣實現滾動的公告效果
- 如何實現報表直接列印需求
- wmsys.wm_concat 實現行列轉換問題
- 試驗Oracle中實現行列轉換的方法(轉)Oracle
- SQL 如何實現動態的行列轉置SQL
- 行列轉換
- 如何實現倒影效果
- 如何實現報表的批次列印需求
- 警示:通過 wmsys.wm_concat 實現行列轉換
- Oracle--SQL行列轉換實戰OracleSQL
- SAP ABAP 報表螢幕輸入欄位如何實現聯動效果試讀版
- 如何實現報表的點選表頭排序需求排序