注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

我的博客

 
 
 

日志

 
 

java ireport jasperreport 配套使用(三) 使用Parameters  

2012-04-09 13:31:59|  分类: JAVA |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

 

在ireport中parameter有几种用法:

1,使用在select sql中,作为查询条件.这种使用较多;

2,单纯在report中显示,例如生成报表的人名字.

 

 

ireport parameters有写内置的parameter(built-in),其值具体是什么,你可以将其拖拽到report上,preview生成报表看看.

 

本将进行如下操作:

将scott模式下 emp表中在deptno为30的emp选出来,并在报表尾部显示生成时间和报表作者.

 

 

1,准备parameters

如下图:

 

2,准备select sql 语句

  1. select * from emp e join dept d  
  2. on e.deptno=d.deptno  
  3. where e.deptno=$P{deptno}  
select * from emp e join dept d on e.deptno=d.deptno 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)

 

  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. }  
package com.jasper; import java.io.IOException; import java.sql.Connection; import java.text.SimpleDateFormat; import java.util.Date; import java.util.HashMap; import java.util.Map; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import com.jasper.connection.JDBCUtils; public class IreportParameterServlet extends HttpServlet { private static final long serialVersionUID = 1L; public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { Map<String, String> paramMap = new HashMap<String, String>(); paramMap.put("reportor", "Young Huijun"); paramMap.put("deptno", "30"); paramMap.put("generateTime", new SimpleDateFormat("yyyy-MM-dd").format( new Date())); Connection conn = JDBCUtils.getInstance().getLocalConnection(); ReportGenerator generator = new ReportGenerator(); generator.PDFGenerator(response, "ireport_parameters.jasper", paramMap, conn); } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { this.doGet(request, response); } }  

 

因为在ireport建了3个parameter,所以paramMap这里put了3个parameter

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

ReportGenerator类请参考java ireport jasperreport 配套使用(二) 

 

 

web.xml

  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>  
<servlet> <servlet-name>IreportParameterServlet</servlet-name> <servlet-class>com.jasper.IreportParameterServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>IreportParameterServlet</servlet-name> <url-pattern>/IreportParameterServlet</url-pattern> </servlet-mapping>  

html

  1. <a href="IreportParameterServlet" mce_href="IreportParameterServlet">use parameter in query sql display data</a><br/>  
<a href="IreportParameterServlet" mce_href="IreportParameterServlet">use parameter in query sql display data</a><br/> 

 

 

生成pdf结果:

 

 

 

  评论这张
 
阅读(2418)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017