Chinaunix首页 | 论坛 | 博客

-

  • 博客访问: 4132051
  • 博文数量: 172
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1923
  • 用 户 组: 普通用户
  • 注册时间: 2018-12-20 14:57
文章分类
文章存档

2021年(19)

2020年(81)

2019年(68)

2018年(4)

我的朋友

分类: 敏捷开发

2019-11-05 16:20:42

来源:https://forums.opentext.com/forums/discussion/61542/compare-current-row-with-previous-row-value#latest

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

本例中有三个字段,其中SELLERID是分组字段,DAY是需要进行比较的字段,字段类型为日期时间型。需要设计一张分组表,SELLERID是分组字段,明细字段是DAY, AMOUNT以及计算列SHIFTTIME, SHIFTTIME中存放着DAY和本组上一条记录中的DAY相差几天。源数据如下:

                                              undefined

用集算器进行数据整理:


A
1 =connect("db").query("select   SELLERID, DAY,AMOUNT,0 as SHIFTTIME    from SALES order by SELLERID, DAY") 查询数据库,对SELLERID,   DAY字段排序,多产生一列常数备用
2 =A1.group(SELLERID).run(~.run(interval(DAY[-1],DAY):SHIFTTIME)) 按SELLERID分组,并在每组数据中修改计算列SHIFTTIME
3 =A2.union() 合并每组数据
4 return   A3 将计算结果返回给报表工具。

将上边SPL代码保存为sales.dfx,然后引入到Birt报表中。Birt调用SPL请参考《》。

第一步:添加集算器JDBC数据源。

undefined

第二步:创建数据集,编辑Query Text。

undefined

第三步:创建报表,报表设计如下:

undefined

第四步:WEB 预览,预览结果如下:

undefined

阅读(1596) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~