Jasper reports Jasper报告在不同页面打印组值

Jasper reports Jasper报告在不同页面打印组值,jasper-reports,ireport,Jasper Reports,Ireport,在使用iReport 4.1.3时,我面临着这个基本问题。我有两张表格“订单”和“订单详情”。 我根据每个订单映射购物车中的各种产品,以了解订单详情。如: 在订单表中,我有: 订单号 123 456 在订单详情表中,我将有: 订单号产品号 123 abc1 123 abc2 456 efg1 456 efg2 456 efg3 我在ireport中创建了以下jrxml: <?xml version="1.0" encoding="UTF-8"?> <jasper

在使用iReport 4.1.3时,我面临着这个基本问题。我有两张表格“订单”和“订单详情”。 我根据每个订单映射购物车中的各种产品,以了解订单详情。如: 在订单表中,我有:

订单号
123
456

在订单详情表中,我将有:
订单号产品号
123 abc1
123 abc2
456 efg1
456 efg2
456 efg3

我在ireport中创建了以下jrxml:

    <?xml version="1.0" encoding="UTF-8"?>
    <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="merchant_invoice" language="groovy" pageWidth="595" pageHeight="842" columnWidth="555" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20">
        <property name="ireport.zoom" value="1.0"/>
        <property name="ireport.x" value="0"/>
        <property name="ireport.y" value="0"/>
        <parameter name="order_ids" class="java.lang.String">
            <defaultValueExpression><![CDATA[]]></defaultValueExpression>
        </parameter>
        <queryString>
            <![CDATA[select
    o.order_id,od.product_id
    from cscart_orders o
    inner join cscart_order_details od on od.order_id=o.order_id
    where o.order_id in ($P{order_ids})]]>
        </queryString>
        <field name="order_id" class="java.math.BigInteger"/>
        <field name="product_id" class="java.math.BigInteger"/>
        <group name="order_id_group" isStartNewPage="true" isReprintHeaderOnEachPage="true">
            <groupExpression><![CDATA[$F{order_id}]]></groupExpression>
            <groupHeader>
                <band height="25">
                    <textField>
                        <reportElement x="6" y="3" width="380" height="20"/>
                        <textElement/>
                        <textFieldExpression><![CDATA["header for order_id "+$F{order_id}]]></textFieldExpression>
                    </textField>
                </band>
            </groupHeader>
            <groupFooter>
                <band height="25">
                    <textField>
                        <reportElement x="8" y="3" width="291" height="20"/>
                        <textElement/>
                        <textFieldExpression><![CDATA["Footer for order id : "+$F{order_id}]]></textFieldExpression>
                    </textField>
                </band>
            </groupFooter>
        </group>
        <background>
            <band splitType="Stretch"/>
        </background>
        <detail>
            <band height="30" splitType="Stretch">
                <textField>
                    <reportElement x="8" y="4" width="270" height="20"/>
                    <textElement/>
                    <textFieldExpression><![CDATA["Products with id :"+$F{product_id}]]></textFieldExpression>
                </textField>
            </band>
        </detail>
    </jasperReport>

但是,当我使用参数“123456”预览它时,我只得到一个页面,其中只包含一级订单(即订单123)的详细信息。 我不明白我哪里做错了。
请提供帮助。

如果您选择多个订单ID,则查询应如下所示

select
o.order_id,od.product_id
from cscart_orders o
inner join cscart_order_details od on od.order_id=o.order_id
where $X{IN,o.order_id,order_ids}
参数order_id的类应该是“java.util.Collection”,您还可以给出默认值表达式

 <parameter name="order_ids" class="java.util.Collection"> 
 <defaultValueExpression><![CDATA[new ArrayList(Arrays.asList(new String[] {"123","456"}))]]></defaultValueExpression>
</parameter>


My framework的开发使得每个参数只能作为字符串传递。此外,将参数作为集合传递仍然没有帮助。我已经更新了答案,并尝试在iReport中为参数提供默认值表达式。