推广 热搜: 收购ACF  石英加热管,  800  T型槽试验平台  求购ACF  深圳回收ACF  回收ACF  T型槽装配平台  求购日立ACF  T型槽地梁 

ireport 、ireport报表开发详解

   日期:2023-04-21     浏览:30    评论:0    
核心提示:ireport闪退Ireport-5.6.0及更早的版本只支持JDK1.7及更低的版本,环境变量配置的不是1.7及以下的话,可以修改配置文件指定jdk路径,修改方法如下:Ireport安装路径下的/e

ireport闪退

Ireport-5.6.0及更早的版本只支持JDK1.7及更低的版本,环境变量配置的不是1.7及以下的话,可以修改配置文件指定jdk路径,修改方法如下:

Ireport安装路径下的/etc/ireport.conf文件:

#jdkhome="/path/to/jdk"

改为

jdkhome="F:JDKJDK_1.7.80" (JDK1.7的安装路)

记得删前面的注释符号#

ireport的使用技巧?

1)配置数据源.

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

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

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

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

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

1 Jack

2 Mike

3 Tony

4 BeckHam

5 Rose

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

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

不是所有的表格区域都是需要的,常用就是title,columnheader,detail,pagefooter,summary我们可以把不需要的隐藏起来. 在报表空排区域右键单击,在弹出的菜单上选择"栏的属性",把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等图象要素

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

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

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

基本名词解析:

chart title expression 图标题表达式

chart subtitle expression 图副标题表达式

show legend 显示图例

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

value axis label expression y轴标签表达式

9.3 放置在正确的区域

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

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

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

一条线的,series是固定值。

ireport静态字段设置太多,PDF上显示不全怎么办?

1.在textfield的属性里面将stretch With OverFlow选上(***是所有的textfield都选上,因为不不能确定每个

textfield的值的高度对吧,这样可以以防万一),这个选项的意思是说:在内容过多时,会自动纵向拉伸

2.在stretch type中选择 relative to Tallest Object ,记住是每个textfield都这么设置,不然,就会出现,只 有你设置了这个属性的textfield会向下自动拉伸,其他的以自己的内容,自适应高度

如果以上设置都不行。那你试试以下方式:

=============================================================================

iReport stretch 选项的注意

Text Field有一选项为Stretch with overflow。 作用是动态的伸展文字所占的空间。

要注意一点是Stretch是跟据Font Name的体字像数为基准进行伸展的。所以当我们输出PDF格式时要注意PDF Font Name 与Font Name是否一致。如不一致在文字量多的时候会出现少了或多了显示空间的问题

(Font设置为宋体,PDF Font设置为STSong-Light,PDF Font encoding设置为UniGB-UCS2-H (Chinese Simplified) 后顺利解决)

iReport Band的[Split allowed]属性

Split allowed是允许分开的意思。以页为单位,被分离出去的是Band内的所有内容。如果剩下的页面空间不够显示Band的内容。那么Band的内容会显示在下一页。

ireport有时侯不能显示数据库中数据的解决方式:

1)每一个element:设置:print when details overflow ;stretch overflow

2)字段高度不够

如何利用ireport实现打印条码标签

1、打开ireport,新建一个文档,用鼠标点击图标拖拽到文档里,这里不累述ireport的使用方法,ireport的使用说明书可以到网上下载。

2、双击

,打开它的属性框,选择图片栏,在图片表达式里输入条码转换的方法,可以查阅如下代码:

3、注意图片表达式类选择java.awt.Image

32

33 package it.businesslogic.ireport.barcode;

34

35

39

40 import java.awt.image.*;

41 import net.sourceforge.barbecue.*;

42 import net.sourceforge.barbecue.linear.ean.UCCEAN128Barcode;

43

44 public class BcImage {

45 private static net.sourceforge.barbecue.Barcode bc = null;

46

47 public static net.sourceforge.barbecue.Barcode getBarcode() {

48 return bc;

49 }

50

51 public static BufferedImage getBarcodeImage(int type, Object aText, boolean showText, boolean checkSum) {

52 return getBarcodeImage(type, aText, showText, checkSum,"",0,0);

53 }

54

55 public static BufferedImage getBarcodeImage(int type, Object aText, boolean showText, boolean checkSum, String applicationIdentifier, int width, int height) {

56 // 2of7, 3of9, Bookland, Codabar, Code128, Code128A, Code128B, Code128C, Code39, EAN128, EAN13, GlobalTradeItemNumber, Int2of5, Int2of5, Monarch, NW7, PDF417, SCC14ShippingCode, ShipmentIdentificationNumber, SSCC18, Std2of5, Std2of5, UCC128, UPCA, USD3, USD4, USPS

57

58 String text = new StringBuffer ().append(aText).toString();

59

60 try {

61 switch (type) {

62 case 0: return null;

63 case 1: bc = BarcodeFactory.create2of7(text); break;

64 case 2: bc = BarcodeFactory.create3of9(text, checkSum); break;

65 case 3: bc = BarcodeFactory.createBookland(text); break;

66 case 4: bc = BarcodeFactory.createCodabar(text); break;

67 case 5: bc = BarcodeFactory.createCode128(text); break;

68 case 6: bc = BarcodeFactory.createCode128A(text); break;

69 case 7: bc = BarcodeFactory.createCode128B(text); break;

70 case 8: bc = BarcodeFactory.createCode128C(text); break;

71 case 9: bc = BarcodeFactory.createCode39(text, checkSum ); break;

72 case 10: bc = BarcodeFactory.createEAN128(text); break;

73 case 11: bc = BarcodeFactory.createEAN13(text); break;

74 case 12: bc = BarcodeFactory.createGlobalTradeItemNumber(text); break;

75 case 13: bc = BarcodeFactory.createInt2of5(text, checkSum); break;

76 case 14: bc = BarcodeFactory.createMonarch(text); break;

77 case 15: bc = BarcodeFactory.createNW7(text); break;

78 case 16: bc = BarcodeFactory.createPDF417(text); break;

79 case 17: bc = BarcodeFactory.createSCC14ShippingCode(text); break;

80 case 18: bc = BarcodeFactory.createShipmentIdentificationNumber(text); break;

81 case 19: bc = new UCCEAN128Barcode(UCCEAN128Barcode.SSCC_18_AI, text, checkSum); break; //BarcodeFactory.createSSCC18(text); break;

82 case 20: bc = BarcodeFactory.createStd2of5(text, checkSum); break;

83 case 21: bc = new UCCEAN128Barcode(applicationIdentifier, text, checkSum); break; //BarcodeFactory.createUCC128(applicationIdentifier, text); break;

84 case 22: bc = BarcodeFactory.createUPCA(text); break;

85 case 23: bc = BarcodeFactory.createUSD3(text, checkSum); break;

86 case 24: bc = BarcodeFactory.createUSD4(text); break;

87 case 25: bc = BarcodeFactory.createUSPS(text); break;

88 case 26: bc = new net.sourceforge.barbecue.linear.code39.Code39Barcode(text, checkSum, true); break;

89 }

90

91 if (width 0) bc.setBarWidth(width);

92 if (height 0) bc.setBarHeight(height);

93 bc.setDrawingText(showText);

94 return net.sourceforge.barbecue.BarcodeImageHandler.getImage(bc);

95 }

96 catch (Exception e) {

97 e.printStackTrace();

98 //generate a runtime exception, invalid value passed.

99 //the user must be notified if fail

100 throw new RuntimeException (e.getMessage());

101 //return null;

102 }

103 }

104 }

iReport中的字段、参数、变量的区别,要怎么使用?

使用:首先确定你的数据库建立好了

IREPORT是这样的,你可以在IREPORT里设置好jrxml(或者jsper)

这东西里面已经包含了数据库链接方式,驱动,以及表名,字段名,查询语句,还有相对应的显示方式(当然是以pdf,html等方式显示)

然后你把jasper或者jrxml放在java目录下,在代码中载入使用比如你可以在ireport里设置数据库链接,并且给一个主键来查询

select * from user where name='xxx',完成其他ireport设置后把jasper文件放到对应的java project目录下

然后你在java代码中载入这个jasper,然后传入这个name的参数

执行后,jasper会根据这个参数执行sql语句,然后取出字段,根据你事先设定的显示方式生成pdf或者html或者其他格式的报表

如果你只是要在jsp里面显示一下字段而已,那么你就直接在jsp里取数据库吧

ireport是报表工具,你不做报表就不需要用ireport

你也可以不用数据库链接,那么你首先在ireport中手动设定字段

生成jasper后在项目的代码中你必须主动为这个jasper输入对应字段的值,然后执行即可

关于ireport和ireport报表开发详解的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

原文链接:http://www.souke.org/news/show-46152.html,转载和复制请保留此链接。
以上就是关于ireport 、ireport报表开发详解全部的内容,关注我们,带您了解更多相关内容。
 
标签: 字段 区域 表达式
打赏
 
更多>同类资讯
0相关评论

推荐资讯
网站首页  |  VIP套餐介绍  |  关于我们  |  联系方式  |  使用协议  |  版权隐私  |  SITEMAPS  |  网站地图  |  排名推广  |  广告服务  |  积分换礼  |  网站留言  |  RSS订阅  |  违规举报