BIRT 交叉表中自由格间运算怎么做

比如要处理这么个场景:1、根据明细记录完成交叉表。2、在交叉表上统计每行的小计(中间过程)。3、计算交叉表中每个值占小计的百分比。计算流程如下图所示:

 

 

BIRT等工具都会提供一些计算列的功能,可以在原始数据基础上再计算出一些别的列值或统计值,所以很容易实现前面2步。但由于传统工具(包含BIRT)没有很好的运算后报表数据项命名机制(一般用列名命名设计阶段的数据单元),很难精确描述数据引用关系,只能写出规律性很强的表达式,而随意的独立格运算就使传统工具难以处理。

常见的解决办法就是写自定义数据集(复杂SQL或scripted data sources),把数据事先计算好后再塞入到报表格子中。但自定义数据集方式,代码非常麻烦,工作量大。

如果使用集算器则会简单很多,其丰富的集合运算可以方便地完成这类计算,比scripted data sources代码要短,比SQL写起来更简单,比如类似的计算在集算器里可以这样写:

 

A

1

=myDB.query@x("select * from record")

2

=A1.pivot(time;department,count)

3

>A2.run(t=Admin+Finance+Management,Admin=string(Admin/t,"0.00%"),Finance=string(Finance/t,"0.00%"),Management=string(Management/t,"0.00%"))

4

return A2

其实还有很多类似的计算问题在BIRT中处理不太方便,但有集算器SPL的辅助却很简单,感兴趣可以参考:解决Birt等报表工具制作报表的几个难题

集算器提供了JDBC驱动,可以很方便的与BIRT等报表工具集成,BIRT调用SPL脚本有使用和获得它的方法。

关于集算器安装使用、获得免费授权和相关技术资料,可以参见如何使用集算器

来源:https://forums.opentext.com/forums/discussion/46297/calculated-column-in-crosstab

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值