如何将参数传递给表组件?

时间:2016-02-09 18:59:02

标签: jasper-reports

我使用Jaspersoft Studio创建报告,我发现将参数传递给表时出现问题。

报告布局和结果

Report layout Result

正如您在这些图片中看到的,当我尝试使用参数来设置表格标题时,我得到null

为了获取值,我在报告参数列表和表数据集参数列表中创建了相同的参数名称。显然,它根本不起作用。

我尝试按照以下说明操作:jaspersoft-passing-parameter-to-tables

但我的数据源来自net.sf.jasperreports.engine.data.JRBeanCollectionDataSource参数,我找不到成功完成教程的方法。

相关代码:

<jasperReport xmlns="http://jasperreports.sourceforge.net/jasperreports" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://jasperreports.sourceforge.net/jasperreports http://jasperreports.sourceforge.net/xsd/jasperreport.xsd" name="subreport" pageWidth="555" pageHeight="802" columnWidth="555" leftMargin="0" rightMargin="0" topMargin="0" bottomMargin="0" uuid="19165c65-293a-42f1-9c92-0f4ceacaaa39">
  .....
  <subDataset name="ATableDataset" uuid="f7f9da25-c513-46bb-92c2-5a97ee76eb5e">
    <parameter name="tableHeadA" class="java.lang.String"/>
    <parameter name="column1AHead" class="java.lang.String"/>
    <parameter name="column2AHead" class="java.lang.String"/>
    <parameter name="column3AHead" class="java.lang.String"/>
    <queryString>
        <![CDATA[]]>
    </queryString>
    <field name="column1A" class="java.lang.String"/>
    <field name="column2A" class="java.lang.String"/>
    <field name="column3A" class="java.lang.String"/>
  </subDataset>
   .....
  <jr:table xmlns:jr="http://jasperreports.sourceforge.net/jasperreports/components" xsi:schemaLocation="http://jasperreports.sourceforge.net/jasperreports/components http://jasperreports.sourceforge.net/xsd/components.xsd">
    <datasetRun subDataset="ATableDataset" uuid="8ac10f33-c9e3-4678-8280-2830a76f72c6">
    <dataSourceExpression><![CDATA[$P{AtableDatasource}]]></dataSourceExpression>
   </datasetRun>
    ....
</jr:table>
......
</jasperReport>

完整代码,请参阅gitHubsample\src\main\resources\subreport.jrxml

1 个答案:

答案 0 :(得分:8)

要将参数传递给表组件,您需要:

<强> 1。使用所需的类

在数据源中定义参数

实施例

<subDataset name="TableDataset" uuid="da383fc2-e830-42d2-a822-6a65972efe4c">
    <parameter name="myParameter" class="java.lang.String"/>
     .......
</subDataset>

<强> 2。使用datasetParameter代码

传递报表参数,变量或字段

实施例

<jr:table xmlns:jr="http://jasperreports.sourceforge.net/jasperreports/components" xsi:schemaLocation="http://jasperreports.sourceforge.net/jasperreports/components http://jasperreports.sourceforge.net/xsd/components.xsd">
   <datasetRun subDataset="TableDataset" uuid="5c37a139-a9dc-4f1b-b231-5dd82794ae4f">
       <datasetParameter name="myParameter">
             <datasetParameterExpression><![CDATA[$P{reportParameter}]]></datasetParameterExpression>
       </datasetParameter>
        <dataSourceExpression><![CDATA[....]]></dataSourceExpression>
   </datasetRun>
    ......
</jr:table>

在你的代码中我找到了1而不是2。