<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

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

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

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

    一、問題描述

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

    二、實現(xiàn)

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

    三、實現(xiàn)步驟

    3.1 定義參數(shù)
    定義一個參數(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語句進行查詢
    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ù)量
    17.     private int colNum = 0;
    18.     // 保存查詢得到列值
    19.     private ArrayList valueList = null;
    20.     // 構(gòu)造函數(shù),定義表結(jié)構(gòu),該表有10個數(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.     // 實現(xiàn)其他四個方法
    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語句進行查詢
    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.     // 釋放一些資源,因為可能會有重復(fù)調(diào)用,所以需釋放valueList,將上次查詢的結(jié)果釋放掉
    107.     public void release() throws Exception {
    108.         super.release();
    109.         this.valueList = null;
    110.     }
    111. }

     

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

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

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


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


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

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

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


     



    主站蜘蛛池模板: 亚欧免费一级毛片| 一级有奶水毛片免费看| 免费观看亚洲人成网站| 羞羞视频在线观看免费| 中文字幕在线免费播放| 少妇太爽了在线观看免费视频 | 免费播放在线日本感人片| 污污网站免费观看| 国产免费看JIZZ视频| 暖暖免费高清日本一区二区三区| 亚洲av手机在线观看| 国产成人精品日本亚洲网站| 亚洲avav天堂av在线不卡| 亚洲校园春色另类激情| 免费无码国产V片在线观看| 免费毛片在线看不用播放器| 97人妻无码一区二区精品免费| 国产无遮挡色视频免费视频| 亚洲日韩精品一区二区三区无码 | 日韩激情淫片免费看| 久久国产成人精品国产成人亚洲 | 亚洲国产美女精品久久久久| 欧洲亚洲国产精华液| 九九精品成人免费国产片| 四虎永久在线精品免费网址| 又粗又大又猛又爽免费视频| 亚洲av无码一区二区三区乱子伦| 亚洲一区二区无码偷拍| 中文字幕无码免费久久9一区9| 成人AV免费网址在线观看| 亚洲人成人网站在线观看| 亚洲国产日韩女人aaaaaa毛片在线| 欧洲精品码一区二区三区免费看| 久久青草免费91线频观看不卡 | 亚洲成a人片毛片在线| 色婷婷精品免费视频| 亚洲成人免费在线观看| 亚洲男人的天堂一区二区| 亚洲国产精品午夜电影| 国产精品免费久久久久电影网| 国产在线观看片a免费观看|