Ireport报表插件使用之二——table组件(Ireport5.6.0版本)

简介: Ireport如何使用table组件,其中list,子表,交叉表也是这种用法

1、如何配置数据源,加载属性参见上一篇博客《Ireport报表插件使用之—参数使用》

2、在ireport中,table与list等个人认为应该算是主报表的子报表(例如:交叉报表,个人认为与table这种组件类似,都是作为子表使用);需要说明的是,子表的数据全部都是来自主表,但是有一点需要说明:子表(table)需要使用字段属性名称必须跟主表的一致。在paramer里面子定义参数作为变量提供给子表使用变量的关联参见下图:

38413db5f2e6c4f27b6befc31b245fc4bdce6aef

3、主表新建外部参数,名字必须对应,Field字段里面的内容从Datasourc(数据库,或者JavaBean)集合传递
7a58d0cd0835db1ad1d1ea97c28483ac45f837c6
4、子表的属性字段(注意:这里注意区分与3的区别,虽然字段file看起来都一样其实是此处是是DataSet标示子表的数据集合);注意如果table上特殊的表头或者标题,需要在子表的paramer里面自定义参数,然后主表也自定义参数,名称可以一致可以不一致,但是需要映射关系,如果映射关系参见:第6步
5b2fa2af9b564ec0a245ed03fc2e73933aecbd75
5、为子表配置 数据源(为DataSet)
556b997b327370c065d624b0da43f187a73a7f01
8c47d2598820099fb3b294cb3d0ebd07254771cc
6、为子表的自定义参数关联主表定义的参数变量,右键选择:
9dc9429f2cb93c8ee2ba11cce13115afffb30860
ecc8f168b652f431e1e648640ee6b6a04326728d
7、 映射主表和子表之间的参数(注意需要双击选择,而不是点击)
da5846e9d2ab06c8aa661a9e3ef4a757e268bef4
8、定义controller层方法返回Model:说明这里的controller层只是在生产环境中或者测试环境使用的时候描述如何返回数据,我们在开发过程中,可以使用javaBeanl来模拟数据,此步骤可以省略
public String selectMajorProdAccumIncome(Model model,HttpServletRequest request){ try { KpiMajorProdIndusAllBO kpiMajorProd = new KpiMajorProdIndusAllBO(); kpiMajorProd.setSheetLevelPro("1"); kpiMajorProd.setStatDate("201803"); List<KpiMajorProdIndusAllBO> list = kpiService.selectDownlodKpiSheet(kpiMajorProd);// 报表数据源 JRBeanCollectionDataSource jrDataSource = new JRBeanCollectionDataSource(list); KpiMajorProdIndusAllVO kpiMajorProdIndusAllVO = new KpiMajorProdIndusAllVO(); kpiMajorProdIndusAllVO.setResultsList(jrDataSource); Collection<KpiMajorProdIndusAllVO> testReports = new Vector<KpiMajorProdIndusAllVO>(); testReports.add(kpiMajorProdIndusAllVO); model.addAttribute("title", DateUtil.getCurrentYear()+"年重点产品收入目标整体跟进表"); // 报表格式 model.addAttribute("ytmDataValueTitle", DateUtil.getCurrentYear()+"年累计收入:万元"); // 报表格式 model.addAttribute("quoYtmDataValueTitle", "份额:%("+DateUtil.getCurrentYearMonth()+")"); // 报表格式 model.addAttribute("nowYear", DateUtil.getCurrentYear()+"年:万元"); // 报表格式 model.addAttribute("lastYear", DateUtil.getLastYear()+"年:万元"); // 报表格式 // 动态指定报表模板url model.addAttribute("url", "/WEB-INF/jasper/KpiMajorProdIndusAllVO.jasper"); model.addAttribute("format", "html"); // 报表格式 model.addAttribute("jrMainDataSource", testReports); }catch(Exception e) { result.setCode(0); result.setData(""); result.setMsg("查询失败"); logger.info("selectMajorProdAccumIncome is error!!!",e); } return "reportView"; // 对应jasper-views.xml中的bean id }
9、定义 Factory工厂类
public class KpiMajorProdIndusAllBOTableFactory {

// 生成实体对象的个数
private static final int RECORD_COUNT = 10;

/**
* 这个方法在iReport的DataResource配置时也会用到 必须是静态方法 static
*
* @return
*/
public static Collection<KpiMajorProdIndusAllTableVO> createBeanCollection() {
Collection<KpiMajorProdIndusAllTableVO> testReports = new Vector<KpiMajorProdIndusAllTableVO>();
Collection<KpiMajorProdIndusAllBO> beanCollection = new ArrayList<KpiMajorProdIndusAllBO>();

for (int i = 0; i < RECORD_COUNT; i++) {
KpiMajorProdIndusAllBO kpiMajorProdIndusAllBO = new KpiMajorProdIndusAllBO();
beanCollection.add(kpiMajorProdIndusAllBO);
}

JRBeanCollectionDataSource resultsList = new JRBeanCollectionDataSource(beanCollection);

KpiMajorProdIndusAllTableVO tr = new KpiMajorProdIndusAllTableVO();

tr.setResultsList(resultsList);

testReports.add(tr);

return testReports;

}
}
10、定义业务Bean
public class KpiMajorProdIndusAllTableBO { private String statDate = "999"; private int num; private String indexCode = "999"; private String indexName = "999"; private String ytmDataValue = "999"; private String lyYtmDataValue = "999"; private String yoyYtmDataValue = "999"; private String quoYtmDataValue = "999"; private String momDataValue = "999"; public KpiMajorProdIndusAllTableBO() { } public String getStatDate() { return statDate; } public void setStatDate(String statDate) { this.statDate = statDate; } public int getNum() { return num; } public void setNum(int num) { this.num = num; } public String getIndexCode() { return indexCode; } public void setIndexCode(String indexCode) { this.indexCode = indexCode; } public String getIndexName() { return indexName; } public void setIndexName(String indexName) { this.indexName = indexName; } public String getYtmDataValue() { return ytmDataValue; } public void setYtmDataValue(String ytmDataValue) { this.ytmDataValue = ytmDataValue; } public String getLyYtmDataValue() { return lyYtmDataValue; } public void setLyYtmDataValue(String lyYtmDataValue) { this.lyYtmDataValue = lyYtmDataValue; } public String getYoyYtmDataValue() { return yoyYtmDataValue; } public void setYoyYtmDataValue(String yoyYtmDataValue) { this.yoyYtmDataValue = yoyYtmDataValue; } public String getQuoYtmDataValue() { return quoYtmDataValue; } public void setQuoYtmDataValue(String quoYtmDataValue) { this.quoYtmDataValue = quoYtmDataValue; } public String getMomDataValue() { return momDataValue; } public void setMomDataValue(String momDataValue) { this.momDataValue = momDataValue; } }
11、定义一个用于封装数据源List的JavaBean,注意:下图中的 resultsList变量名称必须对应该VO的 resultsList名称
public class KpiMajorProdIndusAllTableVO {
JRBeanCollectionDataSource resultsList;

public KpiMajorProdIndusAllTableVO() {

}

public JRBeanCollectionDataSource getResultsList() {

return resultsList;

}

public void setResultsList(JRBeanCollectionDataSource resultsList) {

this.resultsList = resultsList;

}
}

2290d2e8fe770bac3b0348a5f0995f25f33d2f13

12、如果生成的报表有如此大的空白,则是因为你的,面板的Title、PageHeader、ColumnHeader、Detail 1、Column Footer等的属性hight的问题,只要设置为0就行了。
ad37069d72cb5badf9d5c4bf6ed9ff8108364bb8
设置的方式:
128ab117e03f2ba8da8fbf5e6656868376f40327

相关实践学习
基于Hologres轻量实时的高性能OLAP分析
本教程基于GitHub Archive公开数据集,通过DataWorks将GitHub中的项⽬、行为等20多种事件类型数据实时采集至Hologres进行分析,同时使用DataV内置模板,快速搭建实时可视化数据大屏,从开发者、项⽬、编程语⾔等多个维度了解GitHub实时数据变化情况。
阿里云实时数仓实战 - 用户行为数仓搭建
课程简介 1)学习搭建一个数据仓库的过程,理解数据在整个数仓架构的从采集、存储、计算、输出、展示的整个业务流程。 2)整个数仓体系完全搭建在阿里云架构上,理解并学会运用各个服务组件,了解各个组件之间如何配合联动。 3&nbsp;)前置知识要求:熟练掌握 SQL 语法熟悉 Linux 命令,对 Hadoop 大数据体系有一定的了解 &nbsp; 课程大纲 第一章&nbsp;了解数据仓库概念 初步了解数据仓库是干什么的 第二章&nbsp;按照企业开发的标准去搭建一个数据仓库 数据仓库的需求是什么 架构 怎么选型怎么购买服务器 第三章&nbsp;数据生成模块 用户形成数据的一个准备 按照企业的标准,准备了十一张用户行为表 方便使用 第四章&nbsp;采集模块的搭建 购买阿里云服务器 安装 JDK 安装 Flume 第五章&nbsp;用户行为数据仓库 严格按照企业的标准开发 第六章&nbsp;搭建业务数仓理论基础和对表的分类同步 第七章&nbsp;业务数仓的搭建&nbsp; 业务行为数仓效果图&nbsp;&nbsp;
相关文章
|
前端开发 Java 程序员
el-upload上传组件accept属性限制文件类型(案例详解)
案例分享el-upload上传组件accept属性!欢迎留言沟通交流!
4564 0
el-upload上传组件accept属性限制文件类型(案例详解)
|
10月前
|
JSON 供应链 API
京东工业商品详情API数据python解析
京东工业商品详情API专为工业品采购设计,提供商品参数、资质认证、供应链等专业数据,适用于企业采购与供应链管理。支持多SKU查询,采用HTTPS协议与JSON格式,保障数据安全与高效调用。附Python调用示例,便于快速集成。
|
XML Java 应用服务中间件
SpringBoot项目打war包流程
本文介绍了将Spring Boot项目改造为WAR包并部署到外部Tomcat服务器的步骤。主要内容包括:1) 修改pom.xml中的打包方式为WAR;2) 排除Spring Boot内置的Tomcat依赖;3) 添加Servlet API依赖;4) 改造启动类以支持WAR部署;5) 打包和部署。通过这些步骤,可以轻松地将Spring Boot应用转换为适合外部Tomcat服务器的WAR包。
851 64
SpringBoot项目打war包流程
|
12月前
|
人工智能 算法 5G
政务大厅智能引导系统的技术解构:如何用数字基座破解“寻路难”困局?
本文介绍了政务大厅智能导航系统的创新技术与实践应用。未来,智能引导系统将从被动指引进化为主动服务,结合5G、AIoT和数字孪生技术,推动政务服务数字化转型,助力“一网通办”等改革措施落地。
308 1
|
12月前
|
数据采集 人工智能 数据可视化
体育动画直播怎么做出来的?揭秘从数据到卡通的魔法过程!
体育动画直播是一种结合实时数据、游戏引擎与AI技术的创新形式,可将真实比赛数据转化为动画呈现。它支持自由视角观看、100%还原比赛细节,适用于足球/篮球可视化直播、电竞虚拟形象直播等场景。制作流程包括数据采集(如球员定位、生物力学数据)、3D建模(创建虚拟球场与球员模型)、动画生成(关键帧或AI驱动动作)及实时渲染播出。开发者需注意数据清洗、性能优化与版权问题,未来还将融入元宇宙技术,带来全息、VR沉浸式体验。这是一场体育与科技的完美碰撞!
|
移动开发 前端开发 JavaScript
React 图片裁剪组件 Image Cropper
本文介绍了在React中实现图片裁剪功能的方法,涵盖基础知识、常见问题及解决方案。首先,通过第三方库如`react-image-crop`或`cropperjs-react`可轻松实现图片裁剪。接着,针对性能和兼容性问题,提供了优化图片加载、处理裁剪区域响应慢、解决浏览器差异等方案。最后,通过代码案例详细解释了如何创建一个基本的图片裁剪组件,并提出了优化建议,如使用`React.memo`、添加样式支持及处理大图片预览,帮助开发者避免常见错误并提升用户体验。
964 67
|
存储 API 数据安全/隐私保护
使用宝塔搭建MinIO并且设置域名访问
本文介绍了如何使用宝塔面板搭建MinIO并设置域名访问的完整流程。首先通过宝塔面板安装Docker及MinIO,配置域名与端口,完成Web管理界面的部署。接着,创建存储桶、配置访问规则和API密钥,实现资源的安全管理。最后,通过反向代理设置API接口,测试文件上传功能,确保MinIO可用于图片和文件资源的存储。作者Harry技术还分享了相关开源项目,适合开发者快速上手。
2509 2
使用宝塔搭建MinIO并且设置域名访问
|
人工智能 安全 Cloud Native
|
XML JSON Java
Android App网络通信中通过okhttp调用HTTP接口讲解及实战(包括GET、表单格式POST、JSON格式POST 附源码)
Android App网络通信中通过okhttp调用HTTP接口讲解及实战(包括GET、表单格式POST、JSON格式POST 附源码)
2455 0
|
Java Spring 容器
SpringBoot读取配置文件的6种方式,包括:通过Environment、@PropertySource、@ConfigurationProperties、@Value读取配置信息
SpringBoot读取配置文件的6种方式,包括:通过Environment、@PropertySource、@ConfigurationProperties、@Value读取配置信息
3476 3

热门文章

最新文章