Java軟件報(bào)表軟件技術(shù)博客

          java報(bào)表軟件技術(shù)匯總 java報(bào)表軟件制作 報(bào)表軟件新聞
          posts - 355, comments - 100, trackbacks - 0, articles - 3
             :: 首頁 :: 新隨筆 ::  :: 聚合  :: 管理

          我們今天又來講講報(bào)表開發(fā)的事,上周開的這個(gè)系列入門文章也三四天了,瀏覽量不佳小編甚是悲傷啊,希望大家多多支持我!

          一、問題描述

          在實(shí)際應(yīng)用中,可能需要根據(jù)表名動態(tài)地改變數(shù)據(jù)源,比如在程序數(shù)據(jù)集中,通過傳進(jìn)的表名參數(shù),到數(shù)據(jù)庫取出對應(yīng)的表作為數(shù)據(jù)源。因?yàn)?/span>FineReport是通過AbstractTableData抽象類來讀取數(shù)據(jù)源的,而上述所有的數(shù)據(jù)來源都繼承實(shí)現(xiàn)其抽象方法 ,因此用戶只要實(shí)現(xiàn)了AbstractTableData抽象類,也就可以用自定義類型的數(shù)據(jù)源了(程序數(shù)據(jù)集)FineReport報(bào)表引擎就能夠讀取定義的數(shù)據(jù)源作為報(bào)表數(shù)據(jù)源使用。以下就對這種情況舉例說明。

          二、實(shí)現(xiàn)

          與簡單程序數(shù)據(jù)集相同,即繼承AbstractTableData。大家可以參考我上次的文章。

          三、實(shí)現(xiàn)步驟

          3.1 定義參數(shù)
          定義一個(gè)參數(shù),并定義數(shù)據(jù)表結(jié)構(gòu),代碼如下:

          1. public ParamTableDataDemo() { 
          2.             // 定義tableName參數(shù) 
          3.             this.parameters = new Parameter[] { new Parameter("tableName") }; 
          4.             // 定義程序數(shù)據(jù)集列名 
          5.             columnNames = new String[columnNum]; 
          6.             for (int i = 0; i < columnNum; i++) { 
          7.                 columnNames[i] = "column#" + String.valueOf(i); 
          8.             } 
          9.         }

           

          3.2 設(shè)置數(shù)據(jù)
          將數(shù)據(jù)放入到定義的表中,代碼如下:

          1. public void init() {
          2.         // 確保只被執(zhí)行一次
          3.         if (valueList != null) {
          4.             return;
          5.         }
          6.         // 保存得到的數(shù)據(jù)庫表名
          7.         String tableName = parameters[0].getValue().toString();
          8.         // 構(gòu)造SQL語句,并打印出來
          9.         String sql = "select * from " + tableName + ";";
          10.         FRContext.getLogger().info("Query SQL of ParamTableDataDemo: \n" + sql);
          11.         // 保存得到的結(jié)果集
          12.         valueList = new ArrayList();
          13.         // 下面開始建立數(shù)據(jù)庫連接,按照剛才的SQL語句進(jìn)行查詢
          14.         Connection conn = this.getConnection();
          15.         try {
          16.             Statement stmt = conn.createStatement();
          17.             ResultSet rs = stmt.executeQuery(sql);
          18.             // 獲得記錄的詳細(xì)信息,然后獲得總列數(shù)
          19.             ResultSetMetaData rsmd = rs.getMetaData();
          20.             colNum = rsmd.getColumnCount();
          21.             // 用對象保存數(shù)據(jù)
          22.             Object[] objArray = null;
          23.             while (rs.next()) {
          24.                 objArray = new Object[colNum];
          25.                 for (int i = 0; i < colNum; i++) {
          26.                     objArray[i] = rs.getObject(i + 1);
          27.                 }
          28.                 // 在valueList中加入這一行數(shù)據(jù)
          29.                 valueList.add(objArray);
          30.             }
          31.             // 釋放數(shù)據(jù)庫資源
          32.             rs.close();
          33.             stmt.close();
          34.             conn.close();
          35.             // 打印一共取到的數(shù)據(jù)行數(shù)量
          36.          FRContext.getLogger().info(
          37.                     "Query SQL of ParamTableDataDemo: \n" + valueList.size()+ " rows selected");
          38.     } catch (Exception e) {
          39.         e.printStackTrace();
          40.     }
          41. }


          3.3 完整的數(shù)據(jù)集代碼

          完整的帶參程序數(shù)據(jù)集的代碼如下:

          1. package com.fr.data;
          2.     import java.sql.Connection;
          3.     import java.sql.DriverManager;
          4.     import java.sql.ResultSet;
          5.     import java.sql.ResultSetMetaData;
          6.     import java.sql.Statement;
          7.     import java.util.ArrayList;
          8.     import com.fr.base.FRContext;
          9.     import com.fr.data.AbstractTableData;
          10.     import com.fr.base.Parameter;
          11.     public class ParamTableDataDemo extends AbstractTableData {
          12.     // 列名數(shù)組,保存程序數(shù)據(jù)集所有列名
          13.     private String[] columnNames = null;
          14.     // 定義程序數(shù)據(jù)集的列數(shù)量
          15.     private int columnNum = 10;
          16.     // 保存查詢表的實(shí)際列數(shù)量
          17.     private int colNum = 0;
          18.     // 保存查詢得到列值
          19.     private ArrayList valueList = null;
          20.     // 構(gòu)造函數(shù),定義表結(jié)構(gòu),該表有10個(gè)數(shù)據(jù)列,列名為column#0,column#1,。。。。。。column#9
          21.     public ParamTableDataDemo() {
          22.         // 定義tableName參數(shù)
          23.         this.parameters = new Parameter[] { new Parameter("tableName") };
          24.         // 定義程序數(shù)據(jù)集列名
          25.         columnNames = new String[columnNum];
          26.         for (int i = 0; i < columnNum; i++) {
          27.             columnNames[i] = "column#" + String.valueOf(i);
          28.         }
          29.     }
          30.     // 實(shí)現(xiàn)其他四個(gè)方法
          31.     public int getColumnCount() {
          32.         return columnNum;
          33.     }
          34.     public String getColumnName(int columnIndex) {
          35.         return columnNames[columnIndex];
          36.     }
          37.     public int getRowCount() {
          38.         init();
          39.         return valueList.size();
          40.     }
          41.     public Object getValueAt(int rowIndex, int columnIndex) {
          42.         init();
          43.         if (columnIndex >= colNum) {
          44.             return null;
          45.         }
          46.         return ((Object[]) valueList.get(rowIndex))[columnIndex];
          47.     }
          48.     // 準(zhǔn)備數(shù)據(jù)
          49.     public void init() {
          50.         // 確保只被執(zhí)行一次
          51.         if (valueList != null) {
          52.             return;
          53.         }
          54.         // 保存得到的數(shù)據(jù)庫表名
          55.         String tableName = parameters[0].getValue().toString();
          56.         // 構(gòu)造SQL語句,并打印出來
          57.         String sql = "select * from " + tableName + ";";
          58.         FRContext.getLogger().info("Query SQL of ParamTableDataDemo: \n" + sql);
          59.         // 保存得到的結(jié)果集
          60.         valueList = new ArrayList();
          61.         // 下面開始建立數(shù)據(jù)庫連接,按照剛才的SQL語句進(jìn)行查詢
          62.         Connection conn = this.getConnection();
          63.         try {
          64.             Statement stmt = conn.createStatement();
          65.             ResultSet rs = stmt.executeQuery(sql);
          66.             // 獲得記錄的詳細(xì)信息,然后獲得總列數(shù)
          67.             ResultSetMetaData rsmd = rs.getMetaData();
          68.             colNum = rsmd.getColumnCount();
          69.             // 用對象保存數(shù)據(jù)
          70.             Object[] objArray = null;
          71.             while (rs.next()) {
          72.                 objArray = new Object[colNum];
          73.                 for (int i = 0; i < colNum; i++) {
          74.                     objArray[i] = rs.getObject(+ 1);
          75.                 }
          76.                 // 在valueList中加入這一行數(shù)據(jù)
          77.                 valueList.add(objArray);
          78.             }
          79.             // 釋放數(shù)據(jù)庫資源
          80.             rs.close();
          81.             stmt.close();
          82.             conn.close();
          83.             // 打印一共取到的數(shù)據(jù)行數(shù)量
          84.             FRContext.getLogger().info(
          85.                     "Query SQL of ParamTableDataDemo: \n" + valueList.size()+ " rows selected");
          86.         } catch (Exception e) {
          87.             e.printStackTrace();
          88.         }
          89.     }
          90.     // 獲取數(shù)據(jù)庫連接 driverName和 url 可以換成您需要的
          91.     public Connection getConnection() {
          92.         String driverName = "sun.jdbc.odbc.JdbcOdbcDriver";
          93.         String url = "jdbc:odbc:Driver={Microsoft Access Driver (*.mdb)};DBQ=D:\\FineReport_7.0\\WebReport\\FRDemo.mdb";
          94.         String username = "";
          95.         String password = "";
          96.         Connection con = null;
          97.         try {
          98.             Class.forName(driverName);
          99.             con = DriverManager.getConnection(url, username, password);
          100.         } catch (Exception e) {
          101.             e.printStackTrace();
          102.             return null;
          103.         }
          104.         return con;
          105.     }
          106.     // 釋放一些資源,因?yàn)榭赡軙兄貜?fù)調(diào)用,所以需釋放valueList,將上次查詢的結(jié)果釋放掉
          107.     public void release() throws Exception {
          108.         super.release();
          109.         this.valueList = null;
          110.     }
          111. }

           

          編譯ParamTableDataDemo.java ,將生成的ParamTableDataDemo.class類文件拷貝到報(bào)表工程/WEB-INF/classes目錄下。由于該類是在com.fr.data包中的,因此最終應(yīng)該將該類放在/WEB-INF/classes/com/fr/data下面。此時(shí)該程序數(shù)據(jù)源便定義好了。

          3.4 配置程序數(shù)據(jù)集

          新建報(bào)表,在報(bào)表數(shù)據(jù)集中新建程序數(shù)據(jù)源,選擇我們定義好的程序數(shù)據(jù)集,如下圖,名字可以自定義,如divtable


          3.5 
          使用程序數(shù)據(jù)集
          配置好程序數(shù)據(jù)源后便可以使用定義的程序數(shù)據(jù)集了,選中該數(shù)據(jù)集點(diǎn)擊預(yù)覽按鈕,即可以輸入表名動態(tài)地獲取相應(yīng)的數(shù)據(jù)表,并制作模板,如下圖


          注:如果預(yù)覽不出數(shù)據(jù),請確認(rèn)代碼段里面定義數(shù)據(jù)庫連接時(shí)URL的地址是否正確。

          可以看到,我們已經(jīng)將STSCORE表中的數(shù)據(jù)提取至程序數(shù)據(jù)集表中,像其他類型的數(shù)據(jù)集一樣,可以通過拖拽方法實(shí)現(xiàn)單元格數(shù)據(jù)列綁定。

          好啦今天就講到這啦!今天的程序有點(diǎn)多,求關(guān)注,求推薦,求收藏。


           



          主站蜘蛛池模板: 海安县| 望江县| 同德县| 河南省| 灵川县| 天津市| 仁寿县| 吴江市| 河北区| 平原县| 武功县| 石林| 丽水市| 宾阳县| 公安县| 常宁市| 沙坪坝区| 灵石县| 台南市| 绥棱县| 额济纳旗| 慈溪市| 湘西| 峨眉山市| 资溪县| 岳普湖县| 平谷区| 保靖县| 浮山县| 邓州市| 固阳县| 安龙县| 怀安县| 小金县| 东平县| 宜良县| 施秉县| 商洛市| 莫力| 报价| 隆化县|