? 来源:http://developer.actuate.com/community/forum/index.php?/topic/36204-split-data-row/?。
??将字段拆分为多条记录,可以用存储过程或报表脚本来实现,但代码比较复杂,这种情况下可以用集算器来辅助报表工具,下面用例子来说明。
??库表data有两个字段,需要将ANOMOALIES字段按空格拆分为多个字符串,每个字符串和原ID字段形成新的记录。源数据如下:
?
? 集算器代码:
?
? A1:查询数据库。
??A2:拆分ANOMALIES字段,形成新二维表。函数conj可对A1中每个成员的计算结果进行合并。“~”表示集合中的当前成员。结果如下:
?
? A3:将计算结果返回给报表工具。集算器对外提供JDBC接口,报表工具会将集算器识别为普通数据库。
??下面用BIRT设计简单的list表:
?
? 预览:
?
? 报表调用集算器的方法和调用存储过程一样,比如将本脚本保存为BIRTsplitrow.dfx,则在BIRT的存储过程设计器中可以用call?BIRTsplitrow()来调用并输入参数。
原文:http://datamachine.iteye.com/blog/2258022