润乾报表分组求和_带页合计的固定行数分页分组报表

需求说明:

快逸提供了多种灵活的报表分页方式,如按纸分页,按行分页等,另外还可以行后分页可支持表达式,让报表分页更加灵活和便于控制。

客户要求实现的报表要求如下:

1.报表需要按固定行(7行)分页,每页底部添加页合计。

2.报表为分组报表,按”产品类别”分组,每组后需要添加组合计。

实现难点:

1.不能通过设置”按行分页”实现,该方式不能根据分页在每页下方生成”页合计”。

2.不能确定数据集中记录的序号,故难以判断何时进行分页,何时生成”页合计”。

问题解决及需求实现:

1.给数据集中的记录添加序号,这样可以根据添加的序号进行分页分组。

2.通过”行后分页”的方式实现分页,在 “页合计”行设置行后分页。

具体实现如下:

1.用自定义数据集方式为原有的数据集结果添加序号列

原来数据集ds1:SELECT 产品.产品ID,产品.产品名称,产品.单价,产品.库存量,产品.类别ID FROM 产品 WHERE 产品.类别ID is not null ORDER BY 产品.类别ID ASC,产品.产品ID ASC。

得到的结果如下:

用自定义数据集构建数据集ds2,读取ds1的结果,并为其添加序号列。

生成的数据集结果如下:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java8中,可以使用Stream API中的groupingBy方法进行多字段分组求和。下面是一个示例代码: 假设有一个包含以下数据的List: ``` List<Record> records = Arrays.asList( new Record("A", "X", 10), new Record("A", "Y", 20), new Record("B", "X", 30), new Record("B", "Y", 40) ); ``` 其中Record为以下类: ``` class Record { private String group1; private String group2; private int value; public Record(String group1, String group2, int value) { this.group1 = group1; this.group2 = group2; this.value = value; } public String getGroup1() { return group1; } public String getGroup2() { return group2; } public int getValue() { return value; } } ``` 如果要按group1和group2字段进行分组,并对value字段求和,可以使用以下代码: ``` Map<String, Map<String, Integer>> result = records.stream() .collect(Collectors.groupingBy(Record::getGroup1, Collectors.groupingBy(Record::getGroup2, Collectors.summingInt(Record::getValue)))); ``` 这将返回一个Map,其中第一层Map的键为group1字段的值,第二层Map的键为group2字段的值,值为对应的value字段求和的结果。例如,上面的示例代码将返回以下Map: ``` { "A": { "X": 10, "Y": 20 }, "B": { "X": 30, "Y": 40 } } ``` 在以上示例中,我们使用了两个groupingBy方法进行多字段分组,第一个groupingBy方法根据group1字段进行分组,第二个groupingBy方法根据group2字段进行分组,并在最后一个参数中使用summingInt方法对value字段求和

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值