关于Crystal Report动态分组的使用

原创于2007年10月11日,2009年10月15日迁移至此。


很多经验不敢独享,何况我也是踩着前人的臂膀才做出来的,说实话说到数据仓库工具我一向是眼高手低的,攻克这个所谓的技术问题,也算值得高兴一把。

有这样一个需求,假设有这么一张报表

CryStall

用户可能要求按如下组合进行分组:

Factory Name ->Sales Man/Product Name/Employee Name.

Sales Man->Factory Name/Product Name/Sale Date.

Employee Name->Sales Date/Factory Name.

总之:按照两层进行分组,几乎每个数据项都参与进来了

具体做法:

1. 创建一个存储过程,其实本不必创建存储过程的,只不过当时想着顺便把 Crystal Report不能调用 Oracle存储过程的问题也给解决了。很简单 J 获取用户拥有阅读权限所有的表。

CREATE OR REPLACE package RefType
as
TYPE RefCursor IS REF CURSOR;
end;
/

CREATE OR REPLACE procedure gettabnopara ( p_cursor in out RefType.RefCursor )

as

begin

open p_cursor for

select owner , tablespace_name , table_name , 1 as TestNumber

from all_tables ;

end;

/

2. 其他的按照创建报表的一贯做法,选择数据源,选择该存储过程,选择所有相关字段,不必分组,不必过滤,选择缺省模板,一路回过来就 OK了。

3. 创建 Parameter Fields, Default Values中输入想要排序的报表字段

a. 创建 GroupBy Default Values中输入 Owner,Tablespace_Name

b. 创建 SubGroupBy Default Values中输入 Tablespace_Name ,Owner

4. 创建 Formula Fields,将参数和实际字段相关联

a. 创建 GroupBy ,具体公式如下

b. 创建 SubGroupBy ,具体公式如下

if {?GroupBy } = "OWNER" then

{GETTABNOPARA.OWNER}

else

if {?GroupBy } = "TABLESPACE_NAME" then

{GETTABNOPARA.TABLESPACE_NAME}

5. 在报表中点击 Insert Group,选择 GroupBy,SubGroupBy ,插入分组栏目

CryStall

6. 然后在 Group Footer#2,Group Footer#1中插入 Insert Summary

CryStall

7. 最终报表的设计样式如下:

CryStall

所有的报表相关参数参见 Field Explorer图,然后就 OK

CryStall

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

python与大数据分析

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值