ImageVerifierCode 换一换
格式:DOCX , 页数:24 ,大小:566.80KB ,
资源ID:9595902      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/9595902.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(用iReport制作交叉表CrossTabs.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

用iReport制作交叉表CrossTabs.docx

1、用iReport制作交叉表CrossTabs用iReport制作交叉表(CrossTabs) CubeBI.com 立方开源商业智能 一个CrossTabs是一种在设计的时候既不确定行数和也不确定列数的一种表格,在运行环境下它会像下面显示的不同年份的一个销售报表一样。水果/年份200420052006草莓野生樱桃CrossTabs在jasperresports中从1.1.0版本时开始提供,同时iReport也从1.1.0开始支持CrossTabs。Jasperreports的CrossTabs工具允许对行和列的数据进行分组、汇总和自定义每一个cell里的内容。填充CrossTab的数据可以来自

2、主报表里的dataset或来自subDataset。使用iReport里提供的向导我们可以简单快速的创建功能强大的交叉报表组件。一个CrossTabs本质上是一个表格,行和列的数量取决于填充这个表格的数据。行和列也可以在groups里做聚合操作。对于每一个行或列的group我们都可以得到一个细节信息和一个可选的行列数据的汇总。16.1 交叉表向导 (Crosstab wizard)为了说明怎么让一个crosstab工作起来,我们将使用向导创建一个crosstab,当我们在工具条里选择crosstab元素并将其添加到报表中时crosstab的向导会自动启动。还是以DoradoSample里提供的

3、hsql数据里的employee报为例,我们使用包含下面查询语句的空报表开始:Select * from employee我们把crosstab放在报表的底部:summary band图16.1在第一步里我们需要选择一个dataset来填充crosstab,我们这里使用主报表里提供的dataset,点击下一步继续。图16.2在第二步里我们需要定义至少一个行分组.我们这里选择对所有记录使用DEPT_ID进行分组。这样就意味着crosstab的每一行将会采用一个明确的部门编号,这样JasperReports将会使用部门编号对数据集里的数据进行重新整理计算。使用向导,我们可以定义两个行分组,这是使用

4、向导的局限性所在,事实上,如果你需要的话你可以通过Crosstab的属性设置窗口定义若干个行和列的分组。点击下一步继续。和定义行分组一样,从这里我们可以定义两个列分组,这里我们仅使用一个列分组,使用数据中的DEGREE字段对数据进行分组。该字段的含义是学历,这就表示,我们要做的这个交叉报表是用来计算不同部门员工在学历方面的人数分布情况。图16.4是时候定义detail 数据了,一般的,这个detail是使用类似根据country,year得到orders总数或者是相同组合的物品总数的一个聚合函数的计算出来的结果值。我们这里选择打印员工的数量(Detail field:ordered,funct

5、ion:count)。点击下一步继续。图16.5最后一步我们可以为crosstab的布局设定一个布局。我们可以设置是否能看到表格线、或者是否包括行和列总数统计之类。我们这里全部选择。点击finish注意当一个crosstab添加到一个报表中后,会自动在设计窗口中添加一个用来编辑当前crosstab的tab页窗口。图16.6当点击crosstab的tab页,两个新的属性窗口将会被添加在窗口的左边和右边:一个crosstab的结构树,用来显示crosstab的当前选中单元格和帮助相关信息。一个是crossstab对象列表用来显示和该CrossTab相关的一些variables或fields等。当点

6、击工具条上的启动按钮后,我们将可以看到引擎生成的如下效果的报表:图16.7最后一列包含每一行交叉所有列的总计,最后一行包含每一列交叉所有行的总计。16.2 列,行,单元格 (Columns,rows,cells)一个crosstab至少必须有一个行分组和一个列分组,每一个行和列的分组都有一个可选的行/列的统计。下面图中所示的是一个基本的由一个行列分组构成的crosstab。Crosstab header cellColumn group1 headerColumn group 1 total headerRow group 1 headerdetailCol group 1 totalRow

7、group 1 total headerRow group1 totalRow group 1 total/column group 1 total当再次添加一个行分组时,这个crosstab 将会显示出如下效果:Crosstab header cellColumn group1 headerColumn group 1 total headerRow group 1 headerRow group 2 headerdetailCol group 1 totalRow group 2 total headerRow group 2 totalRow group 2 total/column g

8、roup 1 totalRow group 1 total headerRow group1 totalRow group 1 total/column group 1 total16.2.1 行和列 (Rows and columns)一个行或列的分组可能通过crosstab的属性窗口来对它进行修改(在crosstab编辑器右键菜单里选择Crosstab properties)。图16.8点击“row and column groups”的标签页。在这里我们可以看到已经定义好的行或列的分组。图16.9添加一个新的分组请点击名为Add的按钮。图16.10所有分组必须有一个唯一的名称。当你添加或

9、修改一个行分组时,你可以设置row group header的宽度。ROW GROUP WIDTHColumn group1 headerColumn group 1 total headerRow group 1 headerdetailCol group 1 totalRow group 1 total headerRow group1 totalRow group 1 total/column group 1 total“bucket”是分组的标准,它通过一个java类来定义。在一个bucket表达式里,你可以使用主报表里所有的fields/variables/parameters。但是

10、,如果你选择使用subdataset来填充crosstab,那么必须使用subdataset里提供的fields/variables/parameters。一个header的单元格增长依赖于它所跨越的行数。你可以选择多个元素放置在header里。topmiddlebottomstretch最后,你可以选择是否打印出总计的结果。这些选项是:None : 没有总计行被打印Start : 总计行打印在detail行之前End : 总计行打印在detail行之后创建column的group 是非常简单的。定义column group 时你可以定义column的高度来替代行高(看下图)Column gr

11、oup heightColumn group1 headerColumn group 1 total headerRow group 1 headerdetailCol group 1 totalRow group 1 total headerRow group1 totalRow group 1 total/column group 1 total当Bucket在行分组里时,header的单元格内容的定位相似。但是在这个用例中, details可以改变header宽度而不是高度。leftcenterrightstretch再一次,如果打印总计列的话,你可以做一些选择。各选项如下:None :

12、 没有总计列被打印Start : 总计列在detail列之前打印End : 总计列在detail列之后打印列和行的高度可以很容易的在crosstab编辑器里通过鼠标拖曳表格线的方式改变。图16.11当一个行或列添加到crosstab里时,一个特殊的用来引用bucket表达式的变量将要被创建。它和新的group有相同的名称。你可以从crosstab objects 标签里通过查找绿色小点的方式来定位这个bucket variable。图16.12iReport为group创建新的header cells是很简单的,这个操作不需要添加任何新的额外元素到crosstab里。你可以根据你的喜好来填充c

13、ells,最好的方式是通过拖曳把bucket从crosstab objects列表拖到新的单元格里。图16.13图16.14 在上图中,你可以看到加在一个新加的嵌套在column group里四个新添加到crosstab里的单元格,group header单元格,group total header单元格。你可以使用”up”和”down”按钮来更改你的group的嵌套顺序。图16.15下图中所示的crosstab就是在图16.14在SEX 的group被向上移后的效果。图16.16 MONTH group向上移后的效果16.2.2 单元格 (cells)每一个行和列的交叉处定义一个单元格,我们

14、有header单元格,total单元格,detail单元格和一个可选的“when-no-data”单元格。单元格可以包含一个类似于textfields,static texts,rectangle,images之类元素的集合,但是他们不能包含一个SubReport, 一个chart,或者一个crosstab。你可以去修改每一个单元格的背景色和单元格的borders:移动鼠标在一个单元格上并且按右键在弹出的菜单中选择“cell properties”打开单元格属性编辑窗口。从这个对话框中你可以修改单元格的外观。图16.1816.2.3 特殊单元格 (Special cells)如果一个cross

15、tab不能包含一些数据,你可以选择打印别的东西来替代。例如,你可以包含一条消息,方法是,你必须编辑“when-no-data”单元格。在crosstab上右键勾选弹出菜单中的“when-no-data default cell”复选框。这个操作完成后将会出现一种很明显的编辑模式,你可以操作“when-no-data”单元格的内容。图16.19 激活“when-no-data”单元格的编辑模式“when-no-data”单元格和crosstab元素有相同的尺寸。如果没有数据展示的话它将替代crosstab打印。单元格橙色的边框标志出你可以编辑的单元格区域。可以在这个单元格里添加一个或多个元素。在

16、一个crosstab里,所有的元素关联一个单元格,如果一个元素在单元格外面或部分在单元格外面,这是不正确的放置方式并且当编译的时候jasperreports将会抛出异常。iReport在界面中标识这个错误会以红色的框显示。16.2.4 度量 (Measures)在crosstab里每一个元素的表达式(如textfield 表达式)可以包含唯一的measure。在这种情况下,你可以直接使用fields,variables或parameters。一个measure和variable一样是一个对象。要建立一个measure,请打开crosstab属性窗口(在crosstab编辑器上右击,选择cros

17、stab properties)并且到measure标签页。图16.20点击Add按钮,创建一个新的measure。Measure的属性窗口将显示,你最少应该去设置它的name,class type和expression。在measure里你可以使用fields,variable和parameters一个measure可以存储一个来自你代码中的实际的值(将calculation type设为nothing)或者一个类似于用count,sum等计算出来的值。对于每一个measure 你可以提供一个自定义的incrementer类(一个继承自net.sf.jasperreports.engine.

18、fil.JRIncrementerFactory的类)去实现特定的increment 方法。图16.21 measure 属性窗口这里的“percentage of”选项允许你选择表现变量最终值的百分比。你可以提供一个特殊类来计算百分比的值,此时这个类必须实现net.sf.jasperreports.crosstabs.fill.JRPercentageCalculator接口。16.2.5 Crosstab element properties在主设计窗口中双击crosstab元素将打开element properties窗口,点击crosstab标签。图16.22 crosstab ele

19、ment propertiesRepeat column headers : 如果勾选,当crosstab完全添加到页面中时列的header将会被重复打印。Repeat row headers : 如果勾选,当crosstab完全添加到页面中时这个行headers将会被重复打印。Column break offset : 当crosstab超过页面宽度时它指定上一块的数据与下一块之间的空白间隔。图16.23 列被打断后16.2.6 交叉表参数 (Crosstab parameters)你可以使用元素属性窗口里的crosstab parameter表格建立一个crosstab parameter

20、并且设置一个crosstab的parameter同时为其设置一个默认的表达式(图16.22),要添加一个parameter,请点击Add按钮,这个crosstab parameter 窗口将会出现。图16.24对于一个parameter,你必须为其指定name,class type,同时你还可以为其指定一个可选的可以包含主报表中任意一个fields,variable,parameters的表达式。警告:使用dataset的过滤查询,你必须用定义在crosstab properties窗口里的dataset 启动parameters,不能用crosstab里的parameters.你可以在cro

21、sstab objects窗口里看到crosstab parameters的列表,他们用红色的点标记出来。图16.25你可以在启动时用一个MAP来设置crosstab parameters里声明的值。在这个用例中,你需要在element properties窗口里提供一个合法的parameter map expression。16.2.7 交叉表数据 (Crosstab data)你可以用主报表或一个subdataset来填充一个crosstab。在后面的例子中,在crosstab properties窗口“crosstab data”标签里你必须指定要启动的dataset。图16.26如果你

22、的数据是pre-sorted.你可以勾选“Data is presorted”的checkbox以使得填充数据的处理速度加快。Reset type/group和increment type/group选项可以用来定义当集合类型的数据需要重置并且当添加一条记录到你的dataset。关于怎么设置dataset的启动参数请参考subdataset的相关章节。16.2.8 交叉表合计变量 (crosstab total variables)Crosstab variables 是内置的对象,可以结合数据在不同的聚合水平使用在crosstab textfield的表达式里。图16.27对于每一个尺寸,jasperreports创建variables根据每一行或列存储measure的合计值。下面的例子是一个用来显示不同学历不同部门的员工数的报表.图16.28图16.29

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1