我有JasperReports的一个问题。 我想团因一个特定列的值的记录。
例如输入数据:
Name--email--PledgeType--amount
aaa--aa@yahoo.com--1--20.00
bbb--bb@yahoo.com--2--30.00
ccc--cc@gmai.com--1--35.00
ddd--dd@gmai.com--2-- 40.00
输出报告将由“PledgeType”值(1,2,...数)进行分组:
Total for group one: 55.00
Name email amount
aaa aa@yahoo.com 20.00
ccc cc@gmai.com 35.00
------------------------------------
Total for group two: 70.00
Name email amount
bbb bb@yahoo.com 30.00
ddd dd@gmai.com 40.00
JasperReports的能解决这个问题吗? 怎么样?
您可以在JasperReports的定义分组。 JasperReports的计算总的是,有很舒服的方式来添加组和总量。 这里概述您需要的iReport做什么。
要添加组
- 修改您的查询通过pledgeType订购 - JasperReports的需要根据您的分组排序的数据。
- 右键点击报告检查报告,并选择添加报告组 。
- 按照向导,设置为组名PledgeType 并在其中选择场PledgeType 以下报表对象选择组 。 点击下一步。 检查添加组头并单击Finish。
要添加总
- 右键点击在报告中检查变量,然后选择添加变量 。
- 在属性面板中选择此配置:变量类:BigDecimal的,计算:总和,ResetType:集团,ResetGroup PledgeType,变量表达式:
$F{amount}
。 - 拖放变量拖放到报表设计组头。 点击场和变化:文本字段表示:
"Total for group " + $F{PledgeType} + ": " + $V{totalPledge}
,表达类: java.lang.String
。 评估时间:集团。 评价小组:PledgeType。
信息:评价的时间决定何时一个变量被评价时,即当计算的总和将被显示。 如果你把它设置为组就意味着“一旦完成了组处理”。
附生成的报告和JRXML。
该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, 'aa@yahoo.com' as email, 1 as PledgeType, 20.00 as amount
union select 'bbb', 'bb@yahoo.com' ,2, 30.00
union select 'ccc', 'cc@gmai.com' ,1, 35.00
union select 'ddd', 'dd@gmai.com' ,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>