JasperReport是一个开源的java报表制作引擎,ireport是jasperReport的一个GUI工具。我们先使用ireport制作报表的样式,ireport会给我们产生个后缀名为jrxml的文件,然后我们通过java代码向这个模版填充数据,再然后显示出来,它支持输出的文件格式包括PDF,HTML,XHTML,EXCEL等等…一个典型的jrxml文件会包含以下元素:
<Title>: 每个报表一般会有一个名字.
<pageHeader>: 报表的公共要素, 比如页码,创建时间,创建人等信息一般放置在这里.
<columnHeader>: 放列的名称.
<detail>: 放置需要循环输出的数据.
<columnFooter>: 列级别的统计计算值或是列的说明.
<pageFooter>: 放置页级别的统计值或是页的说明.
<lastPageFooter>: 最后一页特殊的格式, 可以放置总结.
<summary>: 只在最后一页才出现.
二.案例:
jasperReport支持多种数据源,下面使用javaBean作为数据源讲解一个简单的例子。
1. java代码
/** * 部门实体 * @author Hewei * */ public class Department { private String name; //部门名称 private List<Staff> staffs; //员工集合 public Department(){} public String getName() { return name; } public void setName(String name) { this.name = name; } public List<Staff> getStaffs() { return staffs; } public void setStaffs(List<Staff> staffs) { this.staffs = staffs; } } /** * 员工实体 * @author Hewei * */ public class Staff { private String name; //姓名 private String sex;//性别 public Staff(){} public String getName() { return name; } public void setName(String name) { this.name = name; } public String getSex() { return sex; } public void setSex(String sex) { this.sex = sex; } }
现在我们已经有个两个存在依赖关系的实体对象,我们要做的就是在一张pdf报表上显示部门名极其以下的员工的信息。 我们还需要一个静态方法向部门实体填充数据,如下…
/** * 数据工厂 * @author HEWEI * */ public class Factory { /** * * @return */ public static List<Department> returnData(){ Staff staff1 = new Staff(); staff1.setName("关羽"); staff1.setSex("男"); Staff staff2 = new Staff(); staff2.setName("张飞"); staff2.setSex("shit"); Staff staff3 = new Staff(); staff3.setName("刘备"); staff3.setSex("男"); List<Department> departments = new ArrayList<Department>(); Department department = new Department(); department.setName("研发部"); List<Staff> staffs = new ArrayList<Staff>(); staffs.add(staff1); staffs.add(staff2); staffs.add(staff3); departments.add(department); return departments; } }
然后我们用javabean 作为报表数据源,我觉得这样是符合mvc规范的,
然而使用sql 查的话, 很麻烦, 要是遇到了 需要 几十张表数据的报表 ,
写sql 很难实现。
详细在附件中