`

JasperReport与hibernate结合使用

阅读更多
花了两天时间,终于把jasperreport与项目中使用的hibernate结合使用.最新版本的ireport支持HQL查询,可以在 ireport里面写HQL语句查询并设计好报表.需要注意的是把hibernate.cfg.xml包括进classpath!!(菜单options ->classpath进行设置)给张图:

test2.jpg

设计好报表之后编译成jasper文件,在servlet中调用,我们需要实现自己的hibernate datasource:

public class HibernateQueryResultDataSource implements JRDataSource {

 private String[] fields;

 private Iterator iterator;

 private Object currentValue;

 public HibernateQueryResultDataSource(List list, String[] fields) {
  this.fields = fields;
  this.iterator = list.iterator();
 }

 public Object getFieldValue(JRField field) throws JRException {
  Object value = null;
  int index = getFieldIndex(field.getName());
  if (index > -1) {
   Object[] values = (Object[]) currentValue;
   value = values[index];
  }
  return value;
 }

 public boolean next() throws JRException {
  currentValue = iterator.hasNext() ? iterator.next() : null;
  return (currentValue != null);
 }

 private int getFieldIndex(String field) {
  int index = -1;
  for (int i = 0; i < fields.length; i++) {
   if (fields[i].equals(field)) {
    index = i;
    break;
   }
  }
  return index;
 }

}

此类构造函数需要两个参数,查询结果的list以及查询的所有属性名(这些属性名必须和报表界面的field名一致)

,使用方式如下:

1.导出pdf:

File reportFile = new File(getServletContext().getRealPath(
    "/reports/" + queryResult.getReportFileName() + ".jasper"));

  HibernateQueryResultDataSource dataSource = new HibernateQueryResultDataSource(
    queryResult.getList(parameters), queryResult.getFields());
  if (reportType.equals("pdf") || reportType.equals("")) {
   try {
    byte[] bytes = JasperRunManager.runReportToPdf(reportFile
      .getPath(), null, dataSource);
    response.setContentType("application/pdf");
    response.setContentLength(bytes.length);
    ServletOutputStream ouputStream = response.getOutputStream();
    ouputStream.write(bytes, 0, bytes.length);
    ouputStream.flush();
    ouputStream.close();

   } catch (Exception e) {
    e.printStackTrace();
   }
  }

2.导出excel,需要把poi-2.0-final-20040126.jar放进web的lib里:

try {

    JasperPrint print = JasperFillManager.fillReport(
      new FileInputStream(reportFile), null, dataSource);
    // JRXlsExporter t=null;
    JRXlsExporter jRXlsExporter = new JRXlsExporter();
    ByteArrayOutputStream xlsReport = new ByteArrayOutputStream();
    jRXlsExporter.setParameter(JRExporterParameter.JASPER_PRINT,
      print);
    jRXlsExporter.setParameter(JRExporterParameter.OUTPUT_STREAM,
      xlsReport);
    jRXlsExporter
      .setParameter(
        JRXlsExporterParameter.IS_REMOVE_EMPTY_SPACE_BETWEEN_ROWS,
        Boolean.TRUE);
    jRXlsExporter.setParameter(
      JRXlsExporterParameter.IS_WHITE_PAGE_BACKGROUND,
      Boolean.TRUE);
    // jRXlsExporter.setParameter(JRExporterParameter.OUTPUT_FILE_NAME,ReportsConstants.bankDetailsHtml);

    // jRXlsExporter.setParameter(JRXlsExporterParameter.IS_ONE_PAGE_PER_SHEET,
    // Boolean.TRUE);

    jRXlsExporter.exportReport();
    byte[] bytes = xlsReport.toByteArray();

   
    response.setContentType("application/vnd.ms-excel");
    response.setContentLength(bytes.length);
    xlsReport.close();
    OutputStream ouputStream = response.getOutputStream();
    ouputStream.write(bytes, 0, bytes.length);
    ouputStream.flush();
    ouputStream.close();

   } catch (Exception e) {
    e.printStackTrace();
   }

分享到:
评论

相关推荐

    Jasperreport资料

    JasperReport可以轻松地与Spring、Struts、Hibernate等Java框架集成,实现报表功能的无缝整合。此外,JasperServer提供了报表服务器功能,支持在线报表设计、权限管理、定时任务等功能,使得报表的管理和分享更为...

    JasperReport+SSH

    - 在Spring中实现业务逻辑,可能涉及到与Hibernate的交互,如查询数据库,获取数据。 - Hibernate负责与数据库进行交互,执行SQL语句,返回结果集。 - 结果集被传递给JasperReport,生成报表,然后以所需的格式(如...

    SSH项目整合案例+jasperreport

    这通常涉及从数据库查询数据,结合业务逻辑,最后通过jasperreport API将数据渲染到报表上。 在“idweb”这个文件夹中,我们可以推测这是项目的源代码或者运行环境。其中可能包括以下组成部分: 1. **配置文件**:...

    JasperReport+iReport报表工具

    JasperReport支持多种数据源,比如JDBC、Hibernate等,这意味着开发者可以从数据库中获取数据,并将其填充到报表中。此外,JasperReport支持导出报表到多种格式,如PDF、Excel、Word和HTML,极大地提高了报表的可用...

    SSH+JASPERREPORT整合例

    SSH+JASPERREPORT整合是将Struts2、Spring和Hibernate这三个开源框架与JasperReports报表工具集成,用于实现复杂的业务数据展示。SSH是企业级Java应用开发的常用框架组合,而JasperReports则是一个强大的报表生成库...

    一个完整的jasperreport+myeclipse+struts2例子

    在JasperReport与MyEclipse的结合中,Struts2可以作为控制器,负责接收用户请求,处理业务逻辑,并调用JasperReport生成的报表服务,最后将报表结果展示给用户。 【学习路径】 学习这个例子,首先你需要熟悉...

    iReport-JasperReport 报表开发指南

    - **HQL 和 Hibernate 连接**: 使用 Hibernate 查询语言 (HQL) 与 ORM 框架 Hibernate 结合使用。 ##### 9.2 JDBC 连接 JDBC 连接是最常用的数据源之一,允许直接查询关系型数据库。配置 JDBC 连接需要指定数据库...

    jasperreport excel报表打印

    ### jasperreport与Excel报表打印知识点 #### 一、JasperReports简介 JasperReports是一款开源的报表工具,主要用于创建复杂、美观的报表,并能够从各种数据源(如:数据库)获取数据,支持多种格式输出,包括PDF、...

    JasperReport开发(一)

    - 数据源广泛,支持JDBC SQL查询、XML文件、CSV文件、HQL(Hibernate查询)、HBase以及JAVA集合等。 - 允许自定义数据源,通过JASPER文件和数据源生成用户所需的文档格式。 ### 3. JasperReport相关文件介绍 - **...

    JPA配置装载 Jboss Envers Jasperreport ireport 项目

    综上所述,本项目结合了JPA进行数据操作,利用Jboss Envers进行数据审计,以及JasperReport和iReport进行报表设计和展示,构建了一个功能丰富的信息系统。这些技术的集成可以提供数据管理、历史追踪以及可视化的报表...

    Jasper Report 报表的使用步骤及应用

    9. **与Hibernate结合**:如果你的项目使用Hibernate作为持久层框架,可以轻松地将报表与Hibernate实体关联。通过Hibernate的数据源,可以直接从ORM映射中获取数据。 10. **创建显示PDF格式报表的JSP文件**:在Web...

    ssh和jasperreports加oracle结合小例子

    在这个小例子中,我们将探讨如何将SSH框架与JasperReports和Oracle数据库相结合,实现数据的动态展示和打印功能。 **Struts2** 是一个用于构建MVC应用程序的Java框架,它提供了处理HTTP请求、管理动作类以及进行...

    struts2JsperReport.rar

    在这个项目中,开发者可能结合了其他几种技术,如Spring2、Hibernate3以及JasperReport,来创建一个功能完善的报表系统。 Spring2是另一个关键组件,它是一个全面的企业级应用框架,提供了依赖注入(DI)和面向切面...

    jasperreports-javaflow-6.3.0.7z_JASPERREPORT_

    填充报表是将设计好的模板与实际数据结合的过程。JasperReports提供了`JasperFillManager`类来进行报表填充,并支持实时数据绑定和分页处理。开发者可以通过设置参数和查询条件来控制填充行为。 4. **导出和展示**...

    Struts2AndJasperReport实例

    Struts2 和 JasperReport 是两种在 Java Web 开发中广泛使用的开源框架,它们结合使用可以构建强大的企业级应用,提供动态数据报告的功能。Struts2 是一个基于 Model-View-Controller(MVC)架构模式的 web 应用框架...

    iReport报表文档

    在Java应用程序中,iReport通常与JasperReport库结合使用,以提供灵活、高效的报表生成能力。本教程将深入探讨iReport和JasperReport的核心功能和使用方法。 一、iReport简介 iReport是基于GUI的报表设计器,它允许...

    japerreport lib

    - 如果报表需要动态生成,可以使用JRBeanCollectionDataSource结合Java集合对象。 总的来说,JasperReport作为一款强大的报表工具,提供了丰富的功能和灵活性,对于需要生成复杂报表的Java项目来说,无疑是一个...

    IReport使用说明

    【IReport使用说明】 IReport是一款基于Java的开源报表设计工具,它是JasperReports库的一部分,...同时,结合标签提及的其他技术,如jasperreport、struts2、spring和hibernate,可以构建出强大的企业级报表系统。

    Struts2AndJasperReport.rar

    本教程将详细讲解如何结合Struts2与JasperReport来创建高效、动态的报表系统。 Struts2是Apache软件基金会下的一个Web应用框架,它提供了强大的控制层结构,使得开发者可以更轻松地构建可维护的、易于测试的Java ...

    java3年工作经验简历_java简历.doc

    在该项目中,他负责基础管理和仓库管理,使用WebService与CRM系统交互,Shiro进行权限控制,JasperReport生成报表。 3. **易装天下人员管理系统** - 基于Spring、Springjpa、Springmvc和Mysql,结合EasyUI和POI开发...

Global site tag (gtag.js) - Google Analytics