JavaBean数据源没有';不要传递给子报表
我很难找到如何正确地将JavaBean DS传递给子报表。我有以下Java代码:JavaBean数据源没有';不要传递给子报表,java,jasper-reports,datasource,subreport,Java,Jasper Reports,Datasource,Subreport,我很难找到如何正确地将JavaBean DS传递给子报表。我有以下Java代码: JRDataSource javaBeansKapitelDS = new JRBeanCollectionDataSource(BeanFactory.generateKapitelCollection()); jasperReport = JasperCompileManager.compileReport("JRXML/Subreports.jrxml"); jasperUnte
JRDataSource javaBeansKapitelDS = new JRBeanCollectionDataSource(BeanFactory.generateKapitelCollection());
jasperReport = JasperCompileManager.compileReport("JRXML/Subreports.jrxml");
jasperUnterkapitelReport = JasperCompileManager.compileReport("JRXML/Subreports_subreport1.jrxml");
jasperEntryReport = JasperCompileManager.compileReport("JRXML/Subreports_subreport1_subreport1.jrxml");
params.put("SUB_DATASOURCE", BeanFactory.generateUnterKapitelCollection());
params.put("SUB_SUB_DATASOURCE", BeanFactory.generateEntryCollection());
jasperPrint = JasperFillManager.fillReport(jasperReport, params, javaBeansKapitelDS);
JasperExportManager.exportReportToPdfFile(jasperPrint, "output/TestJAVABeansDS.pdf");
在主报告中,我有一个报告,它有一个子报告,而子报告又有自己的子报告。在主报表中,我将子报表的数据源设置为datasourceexpressionnew net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($P{SUB_Datasource})
,效果很好
在子报表中,我尝试对子报表执行相同的操作(new net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($p{SUB_SUB_DATASOURCE})
),但我无法将SUB_SUB_DATASOURCE参数从主报表传递到子报表,以便在那里使用它。如果我在主报告中为子报告定义了一个参数:
我有个例外
Caused by: java.lang.NoSuchMethodException: Unknown property '' on class 'class jasperreports.datasource.Entry'
...
Fill 1: exception
net.sf.jasperreports.engine.JRRuntimeException: net.sf.jasperreports.engine.JRException: Error retrieving field value from bean :
...
我正在使用最新的JasperReports库5.5.1
所以我的问题是:如何将JavaBeanSD传递给子报表,以便在子报表中使用它?解决方案非常简单。您已经在将参数传递给子报表,只需在子报表中再次执行相同操作即可将其传递给子报表。让我们把你的报告称为A、B和C。A是主报告,其中包含B,其中包含C 报告A包含以下参数(通过调用
params.put
从Java设置):
报告B包含与报告A相同的参数:
<parameter name="SUB_DATASOURCE" class="java.util.Collection" />
<parameter name="SUB_SUB_DATASOURCE" class="java.util.Collection" />
如果要在报告C中使用该参数,则可以将其包括在内,如下所示:
<subreport>
...
<subreportParameter name="SUB_SUB_DATASOURCE">
<subreportParameterExpression><![CDATA[$P{SUB_SUB_DATASOURCE}]]></subreportParameterExpression>
</subreportParameter>
<dataSourceExpression><![CDATA new net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($P{SUB_SUB_DATASOURCE})]]></dataSourceExpression>
...
</subreport>
<parameter name="SUB_SUB_DATASOURCE" class="java.util.Collection" />
谢谢,您完美地描述了场景!但这正是我已经做过的。第二次我尝试在报告B中使用参数SUB_SUB_DATASOURCE,我得到了上面的异常。
<subreport>
...
<subreportParameter name="SUB_SUB_DATASOURCE">
<subreportParameterExpression><![CDATA[$P{SUB_SUB_DATASOURCE}]]></subreportParameterExpression>
</subreportParameter>
<dataSourceExpression><![CDATA new net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($P{SUB_SUB_DATASOURCE})]]></dataSourceExpression>
...
</subreport>
<parameter name="SUB_SUB_DATASOURCE" class="java.util.Collection" />