Группировка записей в JasperReports

У меня проблема с JasperReports. Я хочу сгруппировать записи в зависимости от одного значения столбца.

Например, входные данные:

Name--email--PledgeType--amount
[email protected]
[email protected]
[email protected]
[email protected] 40.00

Выходной отчет будет сгруппирован по значению "PledgeType" (1, 2,...):

Total for group one: 55.00
Name email         amount
aaa  [email protected] 20.00
ccc  [email protected]  35.00
------------------------------------
Total for group two: 70.00
Name email         amount
bbb  [email protected]  30.00
ddd  [email protected]   40.00

Может ли JasperReports решить эту проблему? как?

Ответ 1

Вы можете определить группировку в JasperReports. JasperReports вычисляет общее количество для вас, есть удобный способ добавления групп и итогов. Вот обзор того, что вам нужно сделать в iReport.

Чтобы добавить группу

  • измените свой запрос на заказ по pledgeType - JasperReports требует, чтобы данные сортировались в соответствии с вашей группировкой.
  • щелкните правой кнопкой мыши отчет в инспекторе отчетов и выберите Добавить группу отчетов.
  • Следуйте указаниям мастера, задайте имя группы PledgeType и выберите Group по следующему объекту отчета, в котором вы выберете поле PledgeType. Нажмите "Далее. Установите флажок Добавить заголовок группы и нажмите" Готово".

Чтобы добавить общий

  • щелкните правой кнопкой мыши на переменных в инспекторе отчетов и выберите "Добавить переменную".
  • На панели свойств выберите эту конфигурацию: Variable class: BigDecimal, Calculation: Sum, ResetType: Group, ResetGroup PledgeType, Variable Expression: $F{amount}.
  • Перетащите переменную в заголовок группы в конструкторе отчетов. Нажмите на поле и измените: выражение текстового поля: "Total for group " + $F{PledgeType} + ": " + $V{totalPledge}, класс выражения: java.lang.String. Время оценки: Группа. Группа оценки: PledgeType.

Info: время оценки решает, когда оценивается переменная, т.е. когда будет показана сумма расчета. Если вы установите его для группировки, это означает "после завершения групповой обработки".

Присоединение сгенерированного отчета и JRXML.

report output

JRXML создается с iReport 5.0 - однако, если вы выполните описанные выше шаги, он должен работать с JR v 2 +

<?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="report2" language="groovy" pageWidth="595" pageHeight="842" columnWidth="555" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20" uuid="ce08fe1c-1543-4460-8613-7f03b200082b">
    <property name="ireport.zoom" value="1.0"/>
    <property name="ireport.x" value="0"/>
    <property name="ireport.y" value="0"/>
    <queryString>
        <![CDATA[select * from
(select 'aaa' as Name, '[email protected]' as email, 1 as PledgeType, 20.00 as amount
union select 'bbb', '[email protected]' ,2, 30.00
union select 'ccc', '[email protected]' ,1, 35.00
union select 'ddd', '[email protected]' ,2, 40.00) tbl
order by PledgeType]]>
    </queryString>
    <field name="Name" class="java.lang.String"/>
    <field name="email" class="java.lang.String"/>
    <field name="PledgeType" class="java.lang.Long"/>
    <field name="amount" class="java.math.BigDecimal"/>
    <variable name="totalPledge" class="java.math.BigDecimal" resetType="Group" resetGroup="PledgeType" calculation="Sum">
        <variableExpression><![CDATA[$F{amount}]]></variableExpression>
    </variable>
    <group name="PledgeType">
        <groupExpression><![CDATA[$F{PledgeType}]]></groupExpression>
        <groupHeader>
            <band height="61">
                <textField evaluationTime="Group" evaluationGroup="PledgeType">
                    <reportElement uuid="401c7b3b-af73-4d40-8982-9c1692eb7085" x="0" y="21" width="555" height="20"/>
                    <textElement/>
                    <textFieldExpression><![CDATA["Total for group " + $F{PledgeType} + ": " + $V{totalPledge}]]></textFieldExpression>
                </textField>
                <staticText>
                    <reportElement uuid="87cd0d21-014d-4e6c-a54a-006165a38414" x="0" y="41" width="185" height="20"/>
                    <textElement/>
                    <text><![CDATA[Name]]></text>
                </staticText>
                <staticText>
                    <reportElement uuid="bd0fc2f5-4963-4c9d-a9be-3659be06e436" x="185" y="41" width="185" height="20"/>
                    <textElement/>
                    <text><![CDATA[email]]></text>
                </staticText>
                <staticText>
                    <reportElement uuid="5d5d7ce1-5353-4f83-91b4-57725b0c922b" x="370" y="41" width="185" height="20"/>
                    <textElement/>
                    <text><![CDATA[amount]]></text>
                </staticText>
            </band>
        </groupHeader>
    </group>
    <detail>
        <band height="20">
            <textField>
                <reportElement uuid="5b325da6-7c56-4357-8808-911dad16ec53" x="0" y="0" width="185" height="20"/>
                <textElement/>
                <textFieldExpression><![CDATA[$F{Name}]]></textFieldExpression>
            </textField>
            <textField>
                <reportElement uuid="0bc06b28-7b8c-4af9-997a-714d1599def1" x="185" y="0" width="185" height="20"/>
                <textElement/>
                <textFieldExpression><![CDATA[$F{email}]]></textFieldExpression>
            </textField>
            <textField>
                <reportElement uuid="e5504bb9-c3c0-4135-94c6-7ea935f97cb6" x="370" y="0" width="185" height="20"/>
                <textElement/>
                <textFieldExpression><![CDATA[$F{amount}]]></textFieldExpression>
            </textField>
        </band>
    </detail>
</jasperReport>