分享
 
 
 

IReport与JasperReport开发详解二

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

IReport与JasperReport开发详解二

3.2.1 设计报表

现在请点击菜单"DataSource"然后选取中"Report query"项,也可以点击图标

,接着IReport会弹出一个对话框(如图):

现在我们在"Report SQL Query"中输入SQL语句"select * from titles",然后去掉"Automatically Retrieve Fields"前面的钩,再点击"Read Fields"将表中的数据字段读出来如图

点击"OK"返回主界面。现在该设计报表的内容了,请点击菜单"View"下的"Report Fields"项,也可以点击工具栏上的图标

,然后你将会得到表中所有的字段名如图:

你可以选择你想要的列,以拖动的方式,将先中的列拖到报表中,这样IReport就会自动的将你所拖动的列进行绑定(可别告诉我你不会拖动这个动作,呵呵),在这里我们只作简单的演式,就不拖动太多的列到报表中,我们只选取取"title_id, pubdate,title"三列就可以了。当然你如果不想用这种简单的方法,要手工添加那也没办法,同样也可以你可以点击工具栏上的图标

,这时你的光标就会变为 一个十形,你可以在报表的任意位置画一个 文本框出来,因为你在报表中画的是一个动态的文本列,这时你得设置它的属性,你可以双击你刚才画的文本框,也可以对着你所画的文本框点击右键,选"Properties"。来设置它的属性。如图:

在默认情况下打开属性窗口后会自动的转到"Text Field"选项卡上,这时你得设置一个与数据库相对应的数据类型, 这个不能出错,否则会在你编译或生成报表时出错(未作测试,不能确定会在那一步出现错误),还有一个我们必须关注的是"TextField expression",在它的输入框中默认为"$F{field}"这时你须要将大括号中的"Field"改 为你表中要指定的列名。如果你要问"$F"代表什么,那你就看下面的这个表就应该知道了。设置好这两个后就可以绑定一个列的数据了。 不过你必须将它放在"detail"区中,否则你在运行报表时可能只能显示一条记录到报表中。为什么这就不用解译了吧!整个报表的空页面 IReport已为你划分好了数据摆放的位置,比如:"title,pageHeader,columnHeader"等等。

元素

名称

引用

变量

variablesName

$V{ variablesName }

参数

parameterName

$P{ parameterName }

字段

filedsName

$F{ filedsName }

现在运行报表总觉得有点单调,我们可以为报表设置一些标题之类的信息,在工具栏中找到

,点击它然后在"Title”区画一个文本框,双击它或点右键选"Properties" 这时出现一个静态文本框的属性窗口,选中"Static Text“选项卡,输入”测试报表“,可以在"Font" 选项卡中选择你希望看到的字体和字号,如图

在这里你也可以不用输入,也可以从数据库中取数据来填充它,具全在"common"选项卡,点击后,你会看到"Print When expression"在它的输入框中输入你所想要的列名,具体操作如上,也要以从右边的三尖角图标

进去,有四个类型"Fields,Parameters,Variables,Formulas"这里只介绍前两种,"Fields"在前面已经说过了,具体操作是一样的,就不再细说,第二种"Parameter"这个参数一般不在IReport中使用,后面再讲。然后按照设置"title"的方式来设置"ColumnName“,做好后你所看到的中文显示不出来,或乱码,怎么办呢?你可以见页底的 FAQ ,现在一个最基本的报表可以认为已经做好了,但是还得调整它的位置,以及上下的边界线,要不然数据显示到页面时会非常的零散。

现在保存,记得最好保存为与你新建报表时的名字一样。理由:“因为在使用文件流来读取报表,然后编译时会出现错误。保存完后点击工具栏上的图标

进行编译,在工具栏上有两个图标一个是执行静态报表用的
,而另一个是用来填充动态报表的
,现在我们只能用动态报表执行的按钮,来填充报表,用前者来执行的话除了你的静态文本之外,其它的显示null。IReport在默认情况下为"JRViewer Preview" ,生成后的效果为:

你也可以在 "Build" 菜单中选择你想要得到的报表格式,如:PDF,XSL,CSV,HTML等...当你选择好后如果没有指定运行你指定生成报表的运行程序的话,它默认会保存到IReport的当前目录中,不会是在你保存报表所在目录。如果你不喜欢看英文界面的话,你可以在菜单"Tools"下的"Options..."可以设置语言,报表的保存位置,备份位置,运行报表所用的程序等等... ...

未完待续

FAQ

1.生成报表时中文产生乱码?

JasperReport的中文处理,须要一个亚洲语言包" iTextAsian.jar,"话到IReport下的lib目录中;然后修改报表的"PDF Font Name"将其改为"STSong-Light",再则是修改"PDF Embedded PDF Encoding" 将其改为"UniGB-UCS2-H(Chinese Simplified)" ,这样就可以解决JasperReport的中文问题了(针对PDF设置的,对Excel也许要少一些,不过这样设置同样也能显示为中文,是不爱引响的)。

2.报表编译时产生NoClassDefFoundException异常?

在代码处理JasperReport时出现该异常,是因为在引用JasperReport的一些jar文件不完整,因工作忙我的处理方式是将JasperReport目录下的Demo\sample\webapp\WEB-INF\lib\所有的jar文件,全引用了,以防不测,同时也没有时间去过多的深究。一定会有一些不必要的包被引用了,如果你有时间可以看一下,再将不必要的jar去掉。

3.另存为PDF时出现UnisupportEncodingException异常?

在报表设计的过程中难免会有小错误,这是因为没有改变"PDF Font Name"应改为"STSong-Light".

下载相关:

IReport下载地址:http://ireport.sourceforge.net

JasperReport下载地址:http://jasperreports.sourceforge.net

iText亚洲语言包下载地址:http://www.lowagie.com/iText

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有