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

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

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

    vjame

    優(yōu)化代碼是無(wú)止境的
    隨筆 - 65, 文章 - 9, 評(píng)論 - 26, 引用 - 0
    數(shù)據(jù)加載中……

    JasperReports學(xué)習(xí)筆記5-其它數(shù)據(jù)生成動(dòng)態(tài)的報(bào)表(WEB)



    一、空數(shù)據(jù)(Empty Datasources)
    就是說(shuō)JRXML文件里面的內(nèi)容都是靜態(tài)的,直接使用
    JREmptyDataSource就行了
    JasperRunManager.runReportToPdfStream(reportStream,  
    servletOutputStream, new HashMap(), new JREmptyDataSource());

    二、Map數(shù)組(Map Datasources)
    有的時(shí)候數(shù)據(jù)不一定要從數(shù)據(jù)庫(kù)里面來(lái),還有可能從Map數(shù)組里面來(lái)成生Map[]的方法

    private Map[] initializeMapArray()
    {
    //你可以把數(shù)組里面的每個(gè)map看成一個(gè)對(duì)象,就相于數(shù)據(jù)庫(kù)里面的每個(gè)字段
    HashMap[] reportRows = new HashMap[4];
    HashMap row1Map = new HashMap();
    HashMap row2Map = new HashMap();
    HashMap row3Map = new HashMap();
    HashMap row4Map = new HashMap();
    row1Map.put("tail_num", "N263Y");
    row1Map.put("aircraft_serial", "T-11");
    row1Map.put("aircraft_model", "39 ROSCOE TRNR RACER");
    row1Map.put("engine_model", "R1830 SERIES");
    row2Map.put("tail_num", "N4087X");
    row2Map.put("aircraft_serial", "BA100-163");
    row2Map.put("aircraft_model", "BRADLEY AEROBAT");
    row2Map.put("engine_model", "R2800 SERIES");
    row3Map.put("tail_num", "N43JE");
    row3Map.put("aircraft_serial", "HAYABUSA 1");
    row3Map.put("aircraft_model", "NAKAJIMA KI-43 IIIA");
    row3Map.put("engine_model", "R1830 SERIES");
    row4Map.put("tail_num", "N912S");
    row4Map.put("aircraft_serial", "9973CC");
    row4Map.put("aircraft_model", "PA18-150");
    row4Map.put("engine_model", "R-1820 SER");
    reportRows[0] = row1Map;
    reportRows[1] = row2Map;
    reportRows[2] = row3Map;
    reportRows[3] = row4Map;
    return reportRows;
    }


    生成JRMapArrayDataSource對(duì)象
    private JRDataSource createReportDataSource()  
    {  
    JRMapArrayDataSource dataSource;  
    Map[] reportRows = initializeMapArray();  
    dataSource = new JRMapArrayDataSource(reportRows);  
    return dataSource;  
    }


    三、Map集合
     
    private JRDataSource createReportDataSource()
    {
    JRMapCollectionDataSource dataSource;
    Collection reportRows = initializeMapCollection();
    dataSource = new JRMapCollectionDataSource(reportRows);
    return dataSource;
    }
    private Collection initializeMapCollection()
    {
    ArrayList reportRows = new ArrayList();
    HashMap row1Map = new HashMap();
    HashMap row2Map = new HashMap();
    HashMap row3Map = new HashMap();
    HashMap row4Map = new HashMap();
    row1Map.put("tail_num", "N263Y");
    row1Map.put("aircraft_serial", "T-11");
    row1Map.put("aircraft_model", "39 ROSCOE TRNR RACER");
    row1Map.put("engine_model", "R1830 SERIES");
    row2Map.put("tail_num", "N4087X");
    row2Map.put("aircraft_serial", "BA100-163");
    row2Map.put("aircraft_model", "BRADLEY AEROBAT");
    row2Map.put("engine_model", "R2800 SERIES");
    row3Map.put("tail_num", "N43JE");
    row3Map.put("aircraft_serial", "HAYABUSA 1");
    row3Map.put("aircraft_model", "NAKAJIMA KI-43 IIIA");
    row3Map.put("engine_model", "R1830 SERIES");
    row4Map.put("tail_num", "N912S");
    row4Map.put("aircraft_serial", "9973CC");
    row4Map.put("aircraft_model", "PA18-150");
    row4Map.put("engine_model", "R-1820 SER");
    reportRows.add(row1Map);
    reportRows.add(row2Map);
    reportRows.add(row3Map);
    reportRows.add(row4Map);
    return reportRows;
    }


    JRDataSource dataSource = createReportDataSource();  
    JasperRunManager.runReportToPdfStream(reportStream,  
    servletOutputStream, new HashMap(), dataSource); 



    四、對(duì)象數(shù)組(Java Objects as Datasources)對(duì)象JAVABEAN

    private JRDataSource createReportDataSource()
    {
    JRBeanArrayDataSource dataSource;
    AircraftData[] reportRows = initializeBeanArray();
    dataSource = new JRBeanArrayDataSource(reportRows);
    return dataSource;
    }

    private AircraftData[] initializeBeanArray()
    {
    AircraftData[] reportRows = new AircraftData[4];
    reportRows[0] = new AircraftData("N263Y", "T-11", "39 ROSCOE TRNR
    RACER", "R1830 SERIES");
    reportRows[1] = new AircraftData("N4087X", "BA100-163", "BRADLEY
    AEROBAT", "R2800 SERIES");
    reportRows[2] = new AircraftData("N43JE", "HAYABUSA 1", "NAKAJIMA
    KI-43 IIIA", "R1830 SERIES");
    reportRows[3] = new AircraftData("N912S", "9973CC", "PA18-150",
    "R-1820 SER");
    return reportRows;
    }

    //最后servlet里面調(diào)用
    JRDataSource dataSource = createReportDataSource();
    JasperRunManager.runReportToPdfStream(reportStream,
    servletOutputStream, new HashMap(), dataSource);



    五、對(duì)象集合
    和對(duì)象數(shù)組基本上一樣,就是最后生成的是JRBeanCollectionDataSource

    private JRDataSource createReportDataSource()
    {
    JRBeanCollectionDataSource dataSource;
    Collection reportRows = initializeBeanCollection();
    dataSource = new JRBeanCollectionDataSource(reportRows);
    return dataSource;
    }

    JRDataSource dataSource = createReportDataSource();
    JasperRunManager.runReportToPdfStream(reportStream,
    servletOutputStream, new HashMap(), dataSource);



    六、XML數(shù)據(jù)成生報(bào)表(XML as Datasource)

    JRXmlDataSource xmlDataSource = new JRXmlDataSource(
    new BufferedInputStream(getServletConfig().getServletContext()
    .getResourceAsStream("/reports/AircraftData.xml")),
    "/AircraftData/aircraft");


    七、json數(shù)據(jù)源

    List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();

            Map
    <String, Object> row1 = new HashMap<String, Object>();
            Map
    <String, Object> row2 = new HashMap<String, Object>();

            Map
    <String, Object> row = new HashMap<String, Object>();
            row.put(
    "field1""001");
            row.put(
    "field2""張三");
            row.put(
    "field3""中國(guó)上海");
            row.put(
    "field4""field4");
            row.put(
    "field5""field5");
            list.add(row);
            row 
    = new HashMap<String, Object>();
            row.put(
    "field1""002");
            row.put(
    "field2""李四");
            row.put(
    "field3""中國(guó)杭州");
            row.put(
    "field4""field4");
            row.put(
    "field5""field5");
            list.add(row);
            row 
    = new HashMap<String, Object>();
            row.put(
    "field1""003");
            row.put(
    "field2""王五");
            row.put(
    "field3""中國(guó)南昌");
            row.put(
    "field4""field4");
            row.put(
    "field5""field5");
            list.add(row);

            row2.put(
    "uAnswer", list);
            row1.put(
    "qNaire", row2);

            JSONObject jsonObject 
    = JSONObject.fromObject(row1);
            String json 
    = jsonObject.toString();

            Map
    <String, Object> jasperPara = new HashMap<String, Object>();
            jasperPara.put(
    "TITLE""json數(shù)據(jù)報(bào)表演示樣例(20131012)");
            InputStream is 
    = new ByteArrayInputStream(json.getBytes());
            jasperPara.put(
    "JSON_INPUT_STREAM", is);
            jasperPara.put(JsonQueryExecuterFactory.JSON_LOCALE, Locale.CHINA);
            jasperPara.put(JRParameter.REPORT_LOCALE, Locale.CHINA);

     


    json數(shù)據(jù)
        {"qNaire"{
              
    "uAnswer": [
                
    {
                  
    "field1""001",    
                  
    "field2""張三",    
                  
    "field3""中國(guó)上海",    
                  
    "field4""field4",
                  
    "field5""field5",
                }
    ,
                
    {
                  
    "field1""002",
                  
    "field2""李四",
                  
    "field3""中國(guó)杭州",
                  
    "field4""field4",
                  
    "field5""field5",
                }
    ,
                
    {
                  
    "field1""003",
                  
    "field2""王五",
                  
    "field3""中國(guó)南昌",
                  
    "field4""field4",
                  
    "field5""field5",
              }

              ]
            }
    }


    ireport配置截圖:
















    posted on 2013-10-15 16:07 lanjh 閱讀(619) 評(píng)論(0)  編輯  收藏 所屬分類: 報(bào)表

    主站蜘蛛池模板: 毛片视频免费观看| 亚洲小视频在线观看| 免费三级毛片电影片| 好湿好大好紧好爽免费视频| 亚洲成av人无码亚洲成av人| 亚洲精品免费在线观看| 亚洲综合伊人久久大杳蕉| 国产成人青青热久免费精品| 免费三级毛片电影片| 18观看免费永久视频| 青柠影视在线观看免费高清 | 二个人看的www免费视频| 亚洲第一综合天堂另类专 | 亚洲三级高清免费| 久久永久免费人妻精品| 亚欧洲精品在线视频免费观看| 亚洲乱妇熟女爽到高潮的片| 亚洲av极品无码专区在线观看| 亚洲综合精品一二三区在线 | 国产啪精品视频网站免费尤物| 日韩免费高清一级毛片| WWW国产亚洲精品久久麻豆| 国产精品高清视亚洲一区二区| 亚洲综合激情视频| 777亚洲精品乱码久久久久久| 亚洲精品无码av人在线观看| 色噜噜亚洲精品中文字幕| 亚洲av无码天堂一区二区三区| 成在线人永久免费视频播放| 最近2019中文免费字幕| 无人在线直播免费观看| 国产精品69白浆在线观看免费| 午夜免费1000部| 麻豆最新国产剧情AV原创免费| 69成人免费视频| 欧美日韩国产免费一区二区三区| 两性刺激生活片免费视频| 成年人性生活免费视频| 在线免费观看a级片| 日本高清免费中文字幕不卡| gogo全球高清大胆亚洲|