1.JasperReport与Hibernate的整合
更改JRXML文件
queryString标签里面加一个属性language="hql",然后里面就不用SQL语句了,写HQL
- <queryString language="hql">
- <![CDATA[from Aircraft aircraft where country = $P{countryCode}
- order by aircraft.id]]>
- </queryString>
JRXML文件里面的field是HQL语言查出来的字段
Hibernate配置文件和DOJO类配置文件都一样,不做更改,而在业务LOGIC上有小的改动
- //输出流
- ServletOutputStream servletOutputStream =
- response.getOutputStream();
- //输入流
- InputStream reportStream = getServlet().getServletConfig()
- .getServletContext().getResourceAsStream("xxxx/xxxx.jasper");
- //设格式为PDF文件
- response.setContentType("application/pdf");
- //Session的创建不变
- SessionFactory sessionFactory = new Configuration().configure().
- buildSessionFactory();
- Session session = sessionFactory.openSession();
- //要在Map里面放入Session
- Map parameterMap = new HashMap();
- parameterMap.put(JRHibernateQueryExecuterFactory.PARAMETER_
- HIBERNATE_SESSION, session);
- //使用JasperFileManager的这个方法,生成jprint文件,如果在WEB里面,可以不生成
- //JasperFillManager.fillReportToFile("/xxx/xxxx.jasper","/xxx/xxx.jprint",session);
- //输出PDF流到WEB页
- JasperRunManager.runReportToPdfStream(reportStream,
- servletOutputStream, parameterMap);
- session.close();
- servletOutputStream.flush();
- servletOutputStream.close();
- return mapping.getInputForward();
就是在生成jprint文件或JasperPrint对象的时候,把JRHibernateQueryExecuterFactory.PARAMETER_
HIBERNATE_SESSION里面的值设为session