使用Jasper或BIRT等报表工具时,常会碰到一些非常规的统计,用报表工具本身或SQL都难以处理,比如与主表相关的子表分布在多个数据库中,报表要展现这些数据源动态关联的结果。集算器具有结构化强计算引擎,集成简单,可以协助报表工具方便地实现此类需求。下面通过一个例子来说明多数据源动态关联的实现过程。
主表org在数据源Master中,org里每条记录对应的子表在不同的数据源中,比如org.org_id=”ORG_S”时,这条记录对应的子表是数据源S_odaURL的User表,org.org_id=”ORG_T”时,这条记录对应的子表是数据源T_odaURL中的User表。子表不止两个,名字都是User,需要和主表动态关联再呈现在报表中。逻辑上的关系如下:
集算器代码如下: