不胜人生一场醉

欢迎来到不胜人生一场醉>>   | 首页 资源中心 | 软件开发 | 软件工程 | 艺术长廊 | 数据仓库专区 | 你的故事我的歌 | 数据库专区 | ITPUB论坛

Crystal Report动态分组

发表人:PercyWang | 发表时间: 2007年十月11日, 12:49

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

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

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. 创建GroupByDefault Values中输入Owner,Tablespace_Name

b. 创建SubGroupByDefault 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

发表评论

标题

在此添加评论

称呼

邮箱地址(可选)

个人主页(可选)


authimage



Valid XHTML 1.0 Strict and CSS. Powered by pLog
Design by Blog.lvwo.com