在Java报表软件中实现数据过滤

作者:finereport

浏览:7,749

发布时间:2023.7.31

当我们想从大量的数据中找到符合一定条件的数据时,我们就会想到利用报表的数据筛选或数据过滤功能来达到这种效果。例如网格式报表中,我们只想获得已付订单的记录:
图表警戒线

FineReport中,我们一般使用两种方式实现报表中数据的筛选与过滤:

方案一:直接通过SQL语句取出满足条件的的数据,如修改数据集SQL语句为:SELECT * FROM 订单 where 是否已付 = true。

方案二:通过数据列过滤来解决。

第一种方案通过直接控制数据源来达到数据过滤与筛选的目的,比较简洁直观,但是这是对于整张报表数据的整体过滤,若是一张报表中不同部分对数据筛选的要求各不相同,则可以使用第二种方案,更加灵活。

以下是通过数据列过滤来实现报表中数据的筛选与过滤的具体方法:

打开报表

打开报表%FR_HOME%WebReportWEB-INFreportletsdocPrimaryDetailReportDetails_3.cpt

设置数据过滤条件

选中订单ID数据列单元格,点击过滤按钮或者双击单元格,选择过滤标签,进入过滤设置对话框,设置过滤条件是否已付等于'true',如下图:
图表警戒线
注:由于单元格的计算顺序,过滤条件需要设置在单元格的父格上,如这里的订单ID,先取出已付的订单号,而其子格会自动继承父格条件,将父格子作为过滤条件。

已完成的模板,可参见%FR_HOME%WebReportWEB-INFreportletsdocPrimaryDetailReportDetails_4.cpt

管理驾驶舱指南,业务指标,数据分析报表需要展现大量的数据和文字,提高信息传递的效率

报表工具产品更多介绍:www.finereport.com


电话咨询
电话咨询
电话热线: 400-811-8890转1
商务咨询: 点击申请专人服务
技术咨询
技术咨询
在线技术咨询: 立即沟通
紧急服务热线: 400-811-8890转2
微信咨询
微信咨询
扫码添加专属售前顾问免费获取更多行业资料
投诉入口
投诉入口
总裁办24H投诉: 173-127-81526
商务咨询