您的位置:首页 > 其它

关于Crystal Report动态分组的使用

2009-10-15 23:16 169 查看
原创于2007年10月11日,2009年10月15日迁移至此。

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

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



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

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
,插入分组栏目



6. 然后在

Group Footer#2,Group Footer#1中插入
Insert Summary



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



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

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: