BIRT 统计图中怎么根据参数实现 X 轴动态分组
关键词导读:动态分组 BIRT统计图根据条件不同显示列不同
报表工具一般擅长处理规则一致的数据,若条件不一致的动态运算在报表中是很难实现的。常见做法是先写段程序把数据源准备好,然后传给BIRT再去画图,而不是在BIRT中去直接处理这种数据并画图。
比如要处理这么个场景:统计图X轴以时间为刻度,根据传入不同参数条件显示不同值。统计1小时,每5分钟一条,要生成12条,期望结果:
统计1天,每小时一条,要生成24条,期望结果:
统计一周,每天一条,要生成7条,期望结果:
可以利用BIRT提供的API修改X轴的刻度,代码大概要写成这样:
... function beforeGeneration( chart, icsc ) { //01 hour 02 day 03 week var type = icsc.getExternalContext().getScriptable().getParameterValue("type"); ... var xAxisArray = chart.getAxes(); xAxisArray[0].setCategoryAxis(false); if(type=='01'){ xAxisArray[0].getScale().setUnit(xAxisArray[0].getScale().getUnit().MINUTES_LITERAL); xAxisArray[0].getScale().setStep(5); }else if(type=='02'){ xAxisArray[0].getScale().setUnit(xAxisArray[0].getScale().getUnit().HOURS_LITERAL); xAxisArray[0].getScale().setStep(1); } else { xAxisArray[0].getScale().setUnit(xAxisArray[0].getScale().getUnit().DAYS_LITERAL); xAxisArray[0].getScale().setStep(1); } } ... |
建议使用集算器,其丰富的集合运算可以方便地完成这类计算,比Java写的代码要短得多,比如类似的计算在集算器里可以这样写(假定数据表为tv,其中发生时刻列为t,统计值列为v):
|
A |
B |
1 |
=[] |
|
2 |
if(type==“hour”) |
>A1=12.(elapse@s(now(),-5*60*~)) |
3 |
else if(type==“day”) |
>A1=24.(elapse@s(now(),-60*60*~)) |
4 |
else if(type==“week”) |
>A1=7.(elapse(now(),-~)) |
5 |
=A1.(demo.query(“select sum(v) from tv where t>? and t<=?”,~, ifn(~[-1],now()))).new(~.v:Value) |
通过接收参数(type)计算起止时间段序列,再根据起止时间段执行SQL进行汇总统计,得到每个时间段内的汇总结果,最后将整个结果集返回给BIRT,按普通统计图的方法去呈现即可。
其实还有很多类似的计算问题不太方便,但有集算器SPL的辅助却很简单,感兴趣可以参考:解决BIRT动态数据源的若干示例
集算器提供了JDBC驱动,可以很方便的与BIRT等报表工具集成,BIRT调用SPL脚本有使用和获得它的方法。
关于集算器安装使用、获得免费授权和相关技术资料,可以参见如何使用集算器。