欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

用BIRT实现报表的组内跨行计算

程序员文章站 2022-05-31 21:16:25
...

   来源:http://developer.actuate.com/community/forum/index.php?/topic/36160-dealing-with-previous-rows-groups-sorts-and-subtotals/

  组内跨行计算一般要用SQL窗口函数或报表脚本去实现,但代码比较复杂,这种情况下可以用集算器来辅助报表工具,下面用例子来说明。

  库表sample有三个字段,其中id是分组字段。需要设计一张分组表,id是分组字段,明细字段是v1,v2以及计算列crossline, crossline的算法是v1+v2+本组内上一条记录中的v1+本组内上一条记录中的v2。源数据如下:

用BIRT实现报表的组内跨行计算
            
    
    博客分类: Java相关 birt分组报表组内计算跨行 

 

   用集算器进行数据整理:

用BIRT实现报表的组内跨行计算
            
    
    博客分类: Java相关 birt分组报表组内计算跨行 
 

   A1:查询数据库,多产生一列常数备用。

  A2:按id分组,并在每组数据中修改计算列crossline,最后合并。计算结果如下:

用BIRT实现报表的组内跨行计算
            
    
    博客分类: Java相关 birt分组报表组内计算跨行 
 A3:将计算结果返回给报表工具。集算器对外提供JDBC接口,报表工具会将集算器识别为普通数据库。

 

  • 用BIRT实现报表的组内跨行计算
            
    
    博客分类: Java相关 birt分组报表组内计算跨行 
  • 大小: 6.5 KB
  • 用BIRT实现报表的组内跨行计算
            
    
    博客分类: Java相关 birt分组报表组内计算跨行 
  • 大小: 20.1 KB
  • 用BIRT实现报表的组内跨行计算
            
    
    博客分类: Java相关 birt分组报表组内计算跨行 
  • 大小: 12.2 KB