gpt4 book ai didi

dataset - iReport,如何打印不同表的字段

转载 作者:行者123 更新时间:2023-12-01 14:44:50 26 4
gpt4 key购买 nike

我的报表中需要多个查询,因此添加了新的数据集。
问题是我无法在报表中使用新数据集的字段,错误是:字段不存在。

因此,如何在报表中有多个查询(以打印不同表的字段)而不为每个字段创建子报表?

谢谢。

最佳答案

不幸的是,这不是iReport的工作方式。您需要将所有数据放入一个数据集中才能并排使用这些字段。有关使用datasetRun的信息,请参见@GenericJon的详细答案,其中您的字段用作定义另一个数据集的输入参数。

如果您确实希望参数可以用于传递数据集运行中的字段以进行输出。这将输出Dataset1> Field1 / Dataset2> Field2。

<subDataset name="TotalUsers">
<parameter name="Users" class="java.lang.Integer" isForPrompting="false"/>
<parameter name="Date" class="java.util.Date" isForPrompting="false"/>
<queryString language="SQL">
<![CDATA[CALL GetTotalUsersAtDate($P{Date})]]>
</queryString>
<field name="TotalUsers" class="java.lang.Long"/>
</subDataset>
...

<componentElement>
<reportElement x="0" y="78" width="555" height="16"/>
<jr:list xmlns:jr="http://jasperreports.sourceforge.net/jasperreports/components" xsi:schemaLocation="http://jasperreports.sourceforge.net/jasperreports/components http://jasperreports.sourceforge.net/xsd/components.xsd" printOrder="Vertical">
<datasetRun subDataset="TotalUsers">
<parametersMapExpression><![CDATA[$P{REPORT_PARAMETERS_MAP}]]></parametersMapExpression>
<datasetParameter name="Users">
<datasetParameterExpression><![CDATA[$F{MusicSubscribers}]]></datasetParameterExpression>
</datasetParameter>
<connectionExpression><![CDATA[$P{REPORT_CONNECTION}]]></connectionExpression>
</datasetRun>
<jr:listContents height="16" width="555">
<textField pattern="#,##0.00 %" isBlankWhenNull="true">
<reportElement style="table_TD" x="475" y="0" width="80" height="16"/>
<textElement/>
<textFieldExpression><![CDATA[$P{Users}.doubleValue()/$F{TotalUsers}.doubleValue()]]></textFieldExpression>
</textField>
<staticText>
<reportElement style="table_TD" x="0" y="0" width="475" height="16"/>
<textElement textAlignment="Left" markup="none"/>
<text><![CDATA[Proportion of total users]]></text>
</staticText>
</jr:listContents>
</jr:list>
</componentElement>

我会进一步建议您在iReport之外进行更多的数学运算和整理,即,如果您的数据源是数据库,则使用存储过程。

关于dataset - iReport,如何打印不同表的字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8657762/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com