ireport5.6使用table组件,怎么用table显示javaBean数据源

ireport5.6使用table组件,怎么用table显示javaBean数据源,第1张

1.从组件面板添加一个table组件到报表中。

2.设计table的字段头.

合并 *** 作

1.

2.

删除你不需要的列

新增你的合并列

3.在报表Parameters里新增一个参数dets(java.util.List)

4.配置table数据集

a.重命令数据集(方便)

右键-》属性,即可修改.

b.添加一个Parameters

新增一个table1(net.sf.jasperreports.engine.JRDataSource)

c.手动配置代码,把dets参数传递给table1接收

<datasetParameter name="table1">

<datasetParameterExpression><![CDATA[new net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($P{dets})]]></datasetParameterExpression>

</datasetParameter>

<dataSourceExpression><![CDATA[new net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($P{dets})]]></dataSourceExpression>

d.添加Fields,显示的字段

5.报表设计完成

6.编写java代码以传递javaBean数据源的方式调用报表并显示

/**

* 打印报表 ckz

*

* @param billcode

* @param req

* @param resp

* @throws Exception

*/

@SuppressWarnings({ "rawtypes", "unchecked" })

@Transactional(readOnly = true)

public void doReport(String billcode,String exportType,HttpServletRequest request,HttpServletResponse response){

try {

String root_path = request.getSession ().getServletContext ().getRealPath ("")

List list = binadjustBillMasDao.queryBinadjustbillDS (billcode)

List datalist = binadjustBillDetDao.queryBinadjustbillDet (billcode)

// 设置report参数

Map params = new HashMap ()

String username = (String) request.getSession ().getAttribute ("employeename")

params.put ("username", username)

params.put ("title", "物资调整单")

params.put ("dets", datalist)

params.put ("SUBREPORT_DIR", root_path + "\\webresource\\reports\\binadjust\\")

params.put ("logo", root_path + IReportConstant.LOGOIMAGEURL)

// 获取打印报表所需的数据

String jaspername = "/binadjust/report_binadjustbill_mas_cn.jasper"

//注:list的size的大小,决定报表里的Detail显示几次,比如:size=2,那么加载后的报表就有2个table显示

JasperHelper.exportmain (exportType, jaspername, list, params, "binadjust", request, response)

} catch (Exception ex) {

PrintWriter out = null

try {

response.setCharacterEncoding ("UTF-8")

out = response.getWriter ()

out.write ("<h1 style='position: absoluteleft: 50%top: 50%margin-left: -180pxmargin-top: -10px'>打印报表出错,请重试!</h1>")

} catch (IOException e) {

e.printStackTrace ()

} finally {

out.close ()

}

ex.printStackTrace ()

}

response.setCharacterEncoding ("UTF-8")

response.setContentType ("text/htmlcharset=UTF-8")

}

1)配置数据源.

选择 DATA-资料/来源 (估计这个是台湾或者香港或者海外华人翻译的菜单),然后在出现的界面选择NEW.

点击next后,按照出现的下图,选择JDBC驱动以及数据库链接路径,输入用户和密码.(假设安装的时候有hr方案).

2)新建一个文档或者说是新建一张报表,菜单是档案->开启新档 (CTRL+N)典型的台湾翻译.

"字段数“原文是column count,其实翻译为”列数“更好一些,意思是一个页面按照纵向分为几个部分,例如有输出为

id, name .如果你选择字段数=2,那么输出的就是形如:

1Jack

2Mike

3Tony

4 BeckHam

5 Rose

3)设置需要的表格区域.

默认的可用区域包括(这在所有的报表中英文都是band):TITLE,PAGEHEADER,COLUMNHEADER,DETAIL,COLUMNFOOTER,PAGEFOOTER,LASTPAGEFOOTER,SUMMARY.

不是所有的表格区域都是需要的,常用就是title,columnheader,detail,pagefooter,summary我们可以把不需要的隐藏起来. 在报表空排区域右键单击,在d出的菜单上选择"栏的属性",把bandheight参数设置为你需要的值,如果不想显示该区域(或者是band或者是栏)可以设置BANDHEIGHT=0.

4) 输入sql

建议用快捷的图标,就是最上一排,大概中间靠右的地方有个圆柱体的图标(鼠标移动到上面会出现database的提示),

点击一下,在出现的窗口输入sql语句如下:

5)摆放字段和设置标题

有工具还是好的,否则工具就没有什么意义了. 点击菜单预览->docking panes->document structure,然后你自己摆放好文档结构栏板,在出现的栏板上展开fileds节点,如图:

注意,这里很重要的: 选中"姓名",按住左键不放,拖到detail 栏目上,然后依次拖动其它三个字段.

顺便说一下,这样的 *** 作对于document structure 中的variables和parameters中的成员也是成立的,对于LIBRARY中变量也是一样的(就是上图的下面部分,显示"page number"等等的地方).

至于对齐这些报表元素,不用说了吧? 看看最下面一栏的快捷按钮你应该明白的.

从最上面一排快捷按钮中找到"不回动的文字"(别扭的翻译),其实就是文本标签. 先点击左键然后放开,然后移动鼠标到columnheader区域,再按住左键不放,在区域中拉出一个矩形区域,则可在该区域放上一个文本标签.依次 *** 作放上其它三个,也可发挥ctrl+c,ctrl+v的功能完成其它三个.

6)设置pagefooter和summary内容.

通常我们都会在页脚放置诸如 "x页/共y页"的字样. 按照前面所说的拖动方法,从library栏板中拖动"page x of y"到pagefooter区域. 然后你可以分别修改需要显示的内容为:"第 " + $V{PAGE_NUMBER} + " 页 " ,"共" + $V{PAGE_NUMBER} + "页".

7)第一次预览.

8)加sql参数条件和计算行数.

通常我们的SQL都会有条件存在的,首先我们假设要查询月薪>=特定数值的员工的报表,则先在DOCUMENT STRUCTURE 栏板(或者面板)中右键单击,选择菜单 add->parameter,

如果你自己不知道应该选择什么类型,但是又需要知道新的参数是什么类型,那么最好的办法是查看detail区域上月薪字段的数据类型,一看是java.math.BigDecimal,那么好,就设置为java.math.BigDecimal.

如果是字符串类型,一般你就不要new然后再转换了,直接输入字符串即可,不过需要加上引号.

修改sql(如前,点击圆柱体图标即可),加上以下语句:

where salary>=$P{salary} ,注意$P表示参数的前缀,$V表示变量的前缀,$F表示字段,名称则在中括号输入.

在summary 栏板中添加变量report_count,然后修改数据类型为字符串,并修改表达式为:"累计人数:"+$V{REPORT_COUNT}.

9)试验一个简单的ireport 折线图

做图是比较有意思的地方,因为美啊! 必须说明的是,例子用的ireport 是2.0.0.

本来想下载jasper的说明,一看要钱,还是$的,就打消了主意,还是自己来吧。

做折线图是比较常见的,没有什么特别的,不过有几点还是需要注意的:

1)构建可用的sql语句,这里有很奇怪的技巧要求,也许以后jasper会修改它们的解析机制.

2)设置图数据集,包括x,y轴的参数,

3)把chart图放置在正确的打印区域(band)

9.1 正确的sql

首先从sql说起,由于在设置series expression(不知道如何翻译更加妥贴一些,暂时翻译为分组表达式)时候是务必要有值的,如果用x或者y的值去作为表达式,直觉来说是不恰当的,所以想想是不是用个常量了,结果还真是.

例句:select mons,cjl,10 N from test_value where jjr='LZF' ORDER BY MONS.

以mons作为x轴,以cjl为y轴,那么N就是连线变量了.N是什么值什么类型不重要,可以是字符串可以是有理数.

这样就可以形成了报表的字段变量$F{MONS},$F{CJL},$F{N}

如果你想多画几条线,那么就用一个会变化的字段来替代N,譬如可以假设有sql如下:

select mons,cjl,jjr n from test_value ORDER BY MONS.

9.2 设置x,y等图象要素

在图上右键点击,在d出的菜单上选择"char properties",然后在d出的窗口中选择“char data"页面,然后选择"char data"页面中的“details"子页,这是关键的地方,然后点击“ADD"按钮,在下图中填入:

"Label expression(optional)"可以不要输入,这是可选项目。"item hyperlink"可以不要理睬,这是用于设置元素超链用的,暂时不要搞这么复杂的.

然后就是设置图的显示属性,如下图(这是选择"chart properties"时候首先就出现的部分):

基本名词解析:

chart title expression 图标题表达式

chart subtitle expression 图副标题表达式

show legend 显示图例

category axis label expressionx轴标签表达式(意译了)

value axis label expression y轴标签表达式

9.3 放置在正确的区域

对于chart务必不能放在detail区域,否则会有奇怪的显示,不知道是本人不精熟还是ireport的bug(也不能要求太多,毕竟这是个非盈利产品,除了它的部分资料).

如果放置在detail区域,那么当sql结果集存在多个行的时候,图就会被画对应的次数,譬如有N行,则图也会出现N个一样的。 所以通常放置在汇总区域(即summary band),不要越界.

最后,用ireport自带的预览工具,可以看到下图:

一条线的,series是固定值。

解决办法是,穿入一个$P的参数,表示图片所在的目录,然后用$P和文件名拼接出

完整的绝对路径. 更好的方法是用InputStream, 例如this.getClass().getResourceAsStream("logo.jpg") ,这时只要把图片放在

当前. jasper所在的目录就可以了,不必考虑什么参数,什么路径了

或者建议你用FineReport,直接邮寄单元格元素,插入图片。FineReport用的人还是蛮多的,ing好用的


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/7994653.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-12
下一篇 2023-04-12

发表评论

登录后才能评论

评论列表(0条)

保存