我想使用grails jasper插件添加到JasperReports 3.7.2中的新表组件。我发现这个新组件对于生成表非常有用。
我已经定义了Table数据集1和一些字段(例如:$ F {name}),问题,我的所有字段值都是null。我还定义了字段(没有附加表格),我得到了值。
这是我的表格代码:
<subDataset name="Table Dataset 1">
<field name="name" class="java.lang.String"/>
<field name="signal" class="java.lang.Double"/>
...
</subDataset>
<componentElement>
<reportElement key="table" style="table" x="0" y="0" width="802" height="50"/>
<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="Table Dataset 1">
<dataSourceExpression><![CDATA[new net.sf.jasperreports.engine.JREmptyDataSource(1)]]></dataSourceExpression>
</datasetRun>
<jr:column width="90">
<jr:columnHeader style="table_CH" height="30" rowSpan="1">
<staticText>
<reportElement x="0" y="0" width="90" height="30"/>
<textElement/>
<text><![CDATA[Name]]></text>
</staticText>
</jr:columnHeader>
<jr:detailCell style="table_TD" height="20" rowSpan="1">
<textField>
<reportElement x="0" y="0" width="90" height="20"/>
<textElement/>
<textFieldExpression class="java.lang.String"><![CDATA[$F{name}]]></textFieldExpression>
</textField>
</jr:detailCell>
</jr:column>
...
我想,我的问题是由于这个部分(我正在使用JREmptyDataSource):
<dataSourceExpression><![CDATA[new net.sf.jasperreports.engine.JREmptyDataSource(1)]]></dataSourceExpression>
但是如何使用Table组件获取<MODEL_DATA>
?
(例如:chain(controller:'jasper',action:'index',model:[data:<MODEL_DATA>
],params:params))
答案 0 :(得分:5)
以下是解决方案:
保持:
<subDataset name="Table Dataset 1">
<field name="name" class="java.lang.String"/>
<field name="signal" class="java.lang.Double"/>
...
</subDataset>
并使用:
<dataSourceExpression><![CDATA[$P{REPORT_DATA_SOURCE}]]></dataSourceExpression>
表组件现在将使用您的实际dataSource(您的MODEL_DATA)!
答案 1 :(得分:1)
上面的答案适用于SQL表达式,但如果您使用的是XML数据源,则还必须包含xPath查询,就像使用主数据集一样。
<subDataset name="Tickets">
<field name="barcode" class="java.lang.String">
<fieldDescription><![CDATA[barcode]]></fieldDescription>
</field>
</subDataset>