网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

Birt中实现组内跨行计算

来源: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相差几天。源数据如下:

                                              Birt 中实现组内跨行计算

用集算器进行数据整理:


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()合并每组数据
4return   A3将计算结果返回给报表工具。

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

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

Birt 中实现组内跨行计算

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

Birt 中实现组内跨行计算

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

Birt 中实现组内跨行计算

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

Birt 中实现组内跨行计算


标题名称:Birt中实现组内跨行计算
文章分享:http://bjjierui.cn/article/jjssih.html

其他资讯