iReport 和 Jasperreport整合开发web报表向导(3)

    技术2022-05-11  96

    让我们先回顾一下上一篇文档中已经阐述的问题: 1. 如何连接数据库? 2. 如何定义变量、参数以及字段? 3. 如何定义字体以及如何使用自定义的字体(如黑体、楷体或者比较艺术化的子体)? 下面我们接着往下阐述余下的两个问题,在开始以前我补充两个因该在上篇文档阐述而没有阐述的地方。        第一个就是我忘记说明iReport怎样把xml文件编译成jasper文件,其实很简单,点击“编译”按钮 即可,其实在你点击两种“运行 ”按钮的是缺省的操作就是先对xml文件进行编译。 第二个就是如何设置iReport的输出格式,我们在前面曾说过iReport可以以很多种格式进行输出,如PDF,HTML,XML,XLS,CVS等等,那么我们该如何设置以何种方式输出呢? 在菜单Build中我们可以看出iReport的缺省输出格式为PDF,如图: PDF preview 缺省输出格 HTML preview 以网页的格式输出 剩下的就不说了,大家试一下就明白了,J 但是只在此设置输出格式了,还没有完成设置,还有一个必需的设置就是,为每一种设置选择执行“环境”,例如,如果你选择以PDF输出,那么你需要为其指明Acrobat Reader的路径,如图选择菜单Tools/Options,则会弹出如下属性页: 这 里还有一点我要说明的就是,在上边途中External editor的设置是选择编辑xml文件的编辑器,这里我一般用UltraEdit来编辑,你可能喜欢用其他的,譬如editplus等,那么就把常用的 xml编辑器输入在这里就可以随心所欲的编辑xml文件了,编辑xml文件进入菜单“Edit/edit XML source”,则会弹出你熟悉的编辑器来编辑该xml文件,如图: 还有最后一点要补充的就是,在上一篇文档中我引入非宋体的字 体的pdfFontName的ttf文件路径都是绝对路径(如:c:winntfontssimhei.ttf),其实这是不对的,应该把你在应用程序中 的字体打包进来,这样改绝对路径为相对路径(如 reportfonts/simhei.ttf),这样就万无一失了,呵呵J 好了,做完上边的补充,让我们接着前面的问题往下进行,先把下面要解决的问题列如下: 4. 如何执行SQL脚本进行查询? 5. 如何把做好的报表引入到应用程序中? 接下来让我们一个问题一个问题的解决它J        4.如何执行SQL脚本进行查询? 我 们大家都知道,从数据查询必须要有查询语句,特别综合查询的时候可能sql语句会复杂的多,那么iReport是怎样让我们使用自己的查询语句进行输出的 呢?我们在上一篇中曾提到过,呵呵J,希望你不会忘记,在菜单view下有Reprot query项,点击则会弹出如下属性页: 点击上图的“Save query to report”则会把这条SQL语句就会把这条查询语句“引入”到报表中了,如果你此时查看XML文件,则会发现如下片断: <queryString><![CDATA[select * from users where name=Jplateau]]></queryString> 此时我们还以上篇文章开始的例子入手,让我们“加工”一下,如下图:     假设我们已经设置好连接数据,那么此时点击“运行”按钮 则会得到如下效果: 呵呵,得到了我们期望的效果,这时,可能你要问,如果我要在sql语句中使用参数呢,那么又该如何?其实我接下来马上要说这个问题,如果我们要以名称来进行模糊查询,传递的参数为name,那么期望的sql语句可能是下面这个样子: Select * from users where name like ‘%name%’ 其实在iReport中也可以很容易实现,记得我们在上一篇文档中曾说过参数的使用方法,因此我不多说,我只把最终的sql语句写给大家,相信大家一看就明白: Select * from users where name like ‘%$P{name}%’ 是不是很简单?J 5. 如何把做好的报表引入到应用程序中? 其实在问题4中,如果要运行带参数的查询报表的话,就会牵涉到问题5的,因此我在这里还是要引用问题4种的例子。 此时我们就要引入一个jsp页面,假设是pdf.jsp,那么下面就是pdf.jsp的代码: <%@ page import="dori.jasper.engine.*" %> <%@ page import="java.util.*" %> <%@ page import="java.io.*" %> <%@ page import="java.sql.*" %> <%        File reportFile = new File(application.getRealPath("/reports/test.jasper"));        Map parameters = new HashMap();        parameters.put("name", "p");               Connection conn=null               //以下忽略得到数据库连接过程 //…… //……                                    byte[] bytes =               JasperRunManager.runReportToPdf(                      reportFile.getPath(),                      parameters,                      conn                      );               response.setContentType("application/pdf");        response.setContentLength(bytes.length);        ServletOutputStream ouputStream = response.getOutputStream();        ouputStream.write(bytes, 0, bytes.length);        ouputStream.flush();        ouputStream.close(); %> 还有一个必要的步骤就是把你下载的Jasperreport.jar放在你应用程序的lib下, 好了,启动你的应用程序,运行dbf.jsp则会看到如下效果 怎么样,根据名称的模糊查询结果是符合我们的期望的,相信你已经掌握了上边的方法了。 当然上边我给出的例子都是最简单的,而且报表的排版也比较随意,相信一点,精美的报表可是细活啊,呵呵J,多练习吧。 总结 这篇系列文档总算写完了,总觉得有点随意的样子,不过还是希望能给一点帮助,文档中不乏有些浅尝辄止的地方,希望你不明白的地方或认为我阐述的不对的地方给我留言或写信。 我的站点:http://plateau.sicool.com/ 邮箱:plateau_t@sina.com ps: 在这篇系列文档中我给了jasperreport太少的篇幅,不是它不重要,虽然iReport可以为我们做到很好,但是对jasperreport的了 解还是很重要的,我很少说明它的另外一个原因我在第一篇文档中也说了,其实jasperreport的配套文档是非常丰富

    最新回复(0)