1. 程式人生 > >java ireport jasperreport 配套使用 三 使用Parameters

java ireport jasperreport 配套使用 三 使用Parameters

分享一下我老師大神的人工智慧教程!零基礎,通俗易懂!http://blog.csdn.net/jiangjunshow

也歡迎大家轉載本篇文章。分享知識,造福人民,實現我們中華民族偉大復興!

               

http://blog.csdn.net/young_smile/article/details/6306858

http://www.packtpub.com/article/graphical-report-design-with-ireport-part1

開始本文之前建議先看過java ireport jasperreport 配套使用(一/二) 

 

在ireport中parameter有幾種用法:

1,使用在select sql中,作為查詢條件.這種使用較多;

2,單純在report中顯示,例如生成報表的人名字.

 

 

ireport parameters有寫內建的parameter(built-in),其值具體是什麼,你可以將其拖拽到report上,preview生成報表看看.

 

本將進行如下操作:

將scott模式下 emp表中在deptno為30的emp選出來,並在報表尾部顯示生成時間和報表作者.

 

 

1,準備parameters

如下圖:

 

2,準備select sql 語句

[java] view plain copy
  1. select * from emp e join dept d  
  2. on e.deptno=d.deptno  
  3. where e.deptno=$P{deptno}  
 

如下圖:

 

$P{deptno}為ireport中表達式的語法.

在ireport寫query sql語句時如果要引用parameter,要使用格式$P{param_name};

在Text控制元件引用field,使用$F{field_name},引用variables,使用$V{var_name}.

 

3,編輯report

1). 將field ename,dname,job,hiredate,sal 拖拽到details band區域;

2). 在column header band區域為每個field新增列名;

3). 在page header band 區域新增一個Text Field控制元件,"All Employees in "+$F{DNAME}+" Department"

4). 在page footer band 區域新增 Generated by $P{reportor] on $P{Time}

如下圖:

 

 

4,最後別忘了修改 report properties:

report language:Java,

when no data:all sections,no detail

 

5,preview 預覽報表.

ireport 3 preview

 

 

 

開啟report建立目錄,兩個檔案:

ireport_parameters.jasper

ireport_parameters.jrxml

將其拷貝到com.jasper.report包下.

 

 

開始Java程式碼呼叫部分.

Servlet(IreportParameterServlet.java)

 

[java] view plain copy
  1. package com.jasper;  
  2. import java.io.IOException;  
  3. import java.sql.Connection;  
  4. import java.text.SimpleDateFormat;  
  5. import java.util.Date;  
  6. import java.util.HashMap;  
  7. import java.util.Map;  
  8. import javax.servlet.ServletException;  
  9. import javax.servlet.http.HttpServlet;  
  10. import javax.servlet.http.HttpServletRequest;  
  11. import javax.servlet.http.HttpServletResponse;  
  12. import com.jasper.connection.JDBCUtils;  
  13. public class IreportParameterServlet extends HttpServlet {  
  14.       
  15.     private static final long serialVersionUID = 1L;  
  16.     public void doGet(HttpServletRequest request, HttpServletResponse response)  
  17.             throws ServletException, IOException {  
  18.         Map<String, String> paramMap = new HashMap<String, String>();  
  19.         paramMap.put("reportor""Young Huijun");  
  20.         paramMap.put("deptno""30");  
  21.         paramMap.put("generateTime"new SimpleDateFormat("yyyy-MM-dd").format( new Date()));  
  22.         Connection conn = JDBCUtils.getInstance().getLocalConnection();  
  23.         ReportGenerator generator = new ReportGenerator();  
  24.         generator.PDFGenerator(response, "ireport_parameters.jasper", paramMap, conn);  
  25.     }  
  26.     public void doPost(HttpServletRequest request, HttpServletResponse response)  
  27.             throws ServletException, IOException {  
  28.         this.doGet(request, response);  
  29.     }  
  30. }  
 

 

因為在ireport建了3個parameter,所以paramMap這裡put了3個parameter

注意:map key值要和ireport parameter name一樣.

ReportGenerator類請參考java ireport jasperreport 配套使用(二) 

 

 

web.xml

[xhtml] view plain copy
  1. <servlet>  
  2.   <servlet-name>IreportParameterServlet</servlet-name>  
  3.   <servlet-class>com.jasper.IreportParameterServlet</servlet-class>  
  4. </servlet>    
  5. <servlet-mapping>  
  6.   <servlet-name>IreportParameterServlet</servlet-name>  
  7.   <url-pattern>/IreportParameterServlet</url-pattern>  
  8. </servlet-mapping>  
 

html

[xhtml] view plain copy
  1. <a href="IreportParameterServlet" mce_href="IreportParameterServlet">use parameter in query sql display data</a><br/>  
 

 

 

生成pdf結果:

 

 


           

給我老師的人工智慧教程打call!http://blog.csdn.net/jiangjunshow

這裡寫圖片描述