1.JasperReport与Hibernate的整合

更改JRXML文件
queryString标签里面加一个属性language="hql",然后里面就不用SQL语句了,写HQL

Xml代码 JasperReport学习笔记8-JasperReport和Hibernate,Struts的整合_Hibernate
  1. <queryStringlanguage="hql">

  2. <![CDATA[from Aircraft aircraft where country = $P{countryCode}

  3. order by aircraft.id]]>

  4. </queryString>


JRXML文件里面的field是HQL语言查出来的字段

Hibernate配置文件和DOJO类配置文件都一样,不做更改,而在业务LOGIC上有小的改动

Java代码 JasperReport学习笔记8-JasperReport和Hibernate,Struts的整合_Hibernate
  1. //输出流

  2. ServletOutputStream servletOutputStream =

  3. response.getOutputStream();

  4. //输入流

  5. InputStream reportStream = getServlet().getServletConfig()

  6. .getServletContext().getResourceAsStream("xxxx/xxxx.jasper");

  7. //设格式为PDF文件

  8. response.setContentType("application/pdf");

  9. //Session的创建不变

  10. SessionFactory sessionFactory = new Configuration().configure().

  11. buildSessionFactory();

  12. Session session = sessionFactory.openSession();

  13. //要在Map里面放入Session

  14. Map parameterMap = new HashMap();

  15. parameterMap.put(JRHibernateQueryExecuterFactory.PARAMETER_

  16. HIBERNATE_SESSION, session);

  17. //使用JasperFileManager的这个方法,生成jprint文件,如果在WEB里面,可以不生成

  18. //JasperFillManager.fillReportToFile("/xxx/xxxx.jasper","/xxx/xxx.jprint",session);

  19. //输出PDF流到WEB页

  20. JasperRunManager.runReportToPdfStream(reportStream,

  21. servletOutputStream, parameterMap);

  22. session.close();

  23. servletOutputStream.flush();

  24. servletOutputStream.close();

  25. return mapping.getInputForward();



就是在生成jprint文件或JasperPrint对象的时候,把JRHibernateQueryExecuterFactory.PARAMETER_
HIBERNATE_SESSION里面的值设为session