iReport-JasperReport报表开发:使用connection填充报表

使用的iReport 和 jasperReport  版本为5.0
在很多时候,使用JRDataSource填充报表相当烦琐,直接在填充中使用connection的话,将会减少很多数据生成的工作,但相对而言在iReport中将需要较多的配置,并且后期更改不是很方便
例子是在报表模板中添加sub dataset的情况,并且使用crosstab,将sub dataset作为crosstab的数据源
  1. 在报表的编辑界面的preview右边的第一个图标设定主dataset的sql,并且使用sql来创建fields
  2. 在Report Inspector的报表中的右键报表,点击Add Dataset添加一个sub dataset,并且为这个sub dataset设定使用sql,如果iReport无法直接连接上数据库,可以先创建一个empty dataset,然后右键点击这个dataset,单击edit query来设定sql语句,并手动为其添加fields
  3. 在summary band中添加crosstab组件,选定第2步中创建的sub dataset这样就配置完了
这种配置的好处是,如果iReport配置数据源可以直接连接上数据库,将可以直接看到需要的报表,在java中使用 JasperFillManager的fillReport接口,使用有connection的填充接口,传输数据库的connection即可完成填充

若要在java代码中动态的修改sql语句,需要注意很多地方:
  • 首先需要使用JRXmlLoader从jrxml文件中获得JasperDesign
  • 然后通过这个JasperDesign的getMainDesignDataset方法获得主dataset
  • 通过JasperDesign的getDatasetMap或者getDatasetList等一些方法获得sub dataset,默认是返回的String-JRDataset的map,需要将JRDataset改成JRDesignDataset
  • 使用这些JRDesignDataset的getQuery方法,获得JRQuery,并将其转换成JRDesignQuery,使用其setText()方法可以修改这些query的sql语句
  • 但是修改了sql之后需要注意各个fields,如果fields名字不一样在填充时将会报错,需要注意,当然这些在JRDesignDataset中也可以获得fields并使用JRDesignField修改即可,需要保证sql读取出来的字段的名字和类型与fields的名字和valueClass一一对应
  • 修改了fields若使用过fields将也需要修改,这将会非常复杂,所以不建议修改sql读取的字段的名字,可以使用as将读取的字段的名字设定为fields的名字
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值