我正在处理需要子报表的报表,因此我想将数据源从 Java 方法传递到子报表,但我没有找到正确的方法。通常我使用以下代码来创建我的报告。将数据源发送到子报表的正确方法是什么?
Map<String, Object> param = new HashMap<>();
param.put("rapportNom", "Module");
param.put("PAR_IMAGE_BACKGROUND", "/dz/suivi/reporting/sources/BackgroundElit.png");
param.put("PAR_IMAGE_HEADER", "/dz/suivi/reporting/sources/headerElit.png");
param.put("SUBREPORT_DIR", "/dz/suivi/reporting/sources/moduleAllDetail_subreport1.jasper");
param.put("SUBREPORT_DATA", "LIST OF OBJECT");
return Reporting.printEtat(getClass().getResourceAsStream("/dz/suivi/reporting/sources/moduleAllDetail.jasper"),
param, new JRBeanCollectionDataSource(reportingModuleViewFacade.findById(module)));
如果您的数据源是List<MyBean>
简单的方法是:
-
Pass it在参数图中
param.put("SUBREPORT_DATA", myBeanList);
-
Definejrxml中的参数
<parameter name="SUBREPORT_DATA" class="java.util.List"/>
-
Create a JRBeanCollection数据源 http://jasperreports.sourceforge.net/api/net/sf/jasperreports/engine/data/JRBeanCollectionDataSource.html使用你的参数
<subreport>
<reportElement x="0" y="0" width="200" height="100" uuid="406c9014-e74b-42d9-b9e1-4af106bfb779"/>
<dataSourceExpression><![CDATA[new net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($P{SUBREPORT_DATA})]]></dataSourceExpression>
<subreportExpression><![CDATA[$P{SUBREPORT_DIR} + "theSubreport.jasper"]]></subreportExpression>
</subreport>
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)