如何将参数从主报表传递到子报表?

时间:2016-01-02 18:51:16

标签: jasper-reports

我想将参数值从主报告传递到子报告。

我尝试了很多方法。此外,我也尝试过此链接中的选项 passing-parameters-from-main-report-to-subreport-to-subreport-in-jasper

主要报告

<?xml version="1.0" encoding="UTF-8"?>
<!-- Created with Jaspersoft Studio version 6.2.0.final using JasperReports Library version 6.2.0  -->
<!-- 2016-01-03T00:04:36 -->
<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="parademo" pageWidth="595" pageHeight="842" columnWidth="555" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20" uuid="4949f116-97b5-453c-8581-61ccb1b3159e">
    <parameter name="TITLEPARA" class="java.lang.String" isForPrompting="false">
        <defaultValueExpression><![CDATA["hi title"]]></defaultValueExpression>
    </parameter>
    <queryString>
        <![CDATA[]]>
    </queryString>
    <background>
        <band splitType="Stretch"/>
    </background>
    <title>
        <band height="79" splitType="Stretch">
            <textField>
                <reportElement x="180" y="36" width="220" height="30" uuid="4ac55979-2248-45d2-a001-3c82b5fec56b"/>
                <textFieldExpression><![CDATA[$P{TITLEPARA}]]></textFieldExpression>
            </textField>
        </band>
    </title>
    <pageHeader>
        <band height="35" splitType="Stretch"/>
    </pageHeader>
    <columnHeader>
        <band height="61" splitType="Stretch"/>
    </columnHeader>
    <detail>
        <band height="286" splitType="Stretch">
            <subreport runToBottom="false">
                <reportElement x="0" y="86" width="560" height="74" uuid="eca8556b-2d65-462f-a3d3-ac95ea6e3ebf"/>
                <subreportParameter name="TITLEPARA">
                    <subreportParameterExpression><![CDATA[$P{TITLEPARA}]]></subreportParameterExpression>
                </subreportParameter>
                <connectionExpression><![CDATA[$P{REPORT_CONNECTION}]]></connectionExpression>
                <subreportExpression><![CDATA["file:/home/rectrix/workspace/jasper/subparam.jrxml"]]></subreportExpression>
            </subreport>
        </band>
    </detail>
    <columnFooter>
        <band height="45" splitType="Stretch"/>
    </columnFooter>
    <pageFooter>
        <band height="54" splitType="Stretch"/>
    </pageFooter>
    <summary>
        <band height="42" splitType="Stretch"/>
    </summary>
</jasperReport>

子报告

<?xml version="1.0" encoding="UTF-8"?>
<!-- Created with Jaspersoft Studio version 6.2.0.final using JasperReports Library version 6.2.0  -->
<!-- 2016-01-03T00:04:17 -->
<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="subparam" pageWidth="595" pageHeight="842" columnWidth="555" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20" uuid="b4c019e3-0dc2-425c-b449-908c4fd21bde">
    <property name="com.jaspersoft.studio.data.defaultdataadapter" value="MainReportDataSet"/>
    <parameter name="TITLEPARA" class="java.lang.String" isForPrompting="false"/>
    <queryString>
        <![CDATA[]]>
    </queryString>
    <background>
        <band splitType="Stretch"/>
    </background>
    <title>
        <band height="79" splitType="Stretch">
            <textField>
                <reportElement x="140" y="45" width="100" height="30" uuid="6b9d5038-4163-47ed-a0cd-812f07b27ff0"/>
                <textFieldExpression><![CDATA[$P{TITLEPARA}]]></textFieldExpression>
            </textField>
        </band>
    </title>
    <pageHeader>
        <band height="35" splitType="Stretch"/>
    </pageHeader>
    <columnHeader>
        <band height="61" splitType="Stretch"/>
    </columnHeader>
    <detail>
        <band height="125" splitType="Stretch"/>
    </detail>
    <columnFooter>
        <band height="45" splitType="Stretch"/>
    </columnFooter>
    <pageFooter>
        <band height="54" splitType="Stretch"/>
    </pageFooter>
    <summary>
        <band height="42" splitType="Stretch"/>
    </summary>
</jasperReport>

我可以使用主报告title频段中的参数打印“HI TITLE”。

我想使用参数将此值传递给子报告,并将其打印在子报告的title范围内。

我想仅使用参数传递此值,因为我想知道参数是如何工作的,所以我可以将它用于我的项目,通过参数将值传递给子报告。

1 个答案:

答案 0 :(得分:2)

您正在传递参数正确,这不是您的问题。

使用您的示例文件可以解决这些问题。

  1. 如果数据源为空,则需要whenNoDataType="AllSectionsNoDetail"标记上的属性jasperReport来显示内容(包括主报表和子报表)。

  2. 子报告不能位于detail个频段(因为您的数据源为空),请将其移至另一个频段示例title频段。

  3. 您无法在subreportExpression中引用 jrxml ,您需要引用.jasper文件(已编译时为jrxml) 。注意:路径需要是文件的绝对路径(通常使用一个参数,以便在运行时传递它)

  4. 有关子报告Subreport not rendering in main report

    的路径的详细信息,请参阅此处

    为了进行测试,我建议您在子报表中放置另一个静态文本元素,以便了解子报表是否显示。