这是最好的时代,这是最坏的时代,这是智慧的时代,这是愚蠢的时代;这是信仰的时期,这是怀疑的时期;这是光明的季节,这是黑暗的季节;这是希望之春,这是失望之冬;人们面前有着各样事物,人们面前一无所有;人们正在直登天堂;人们正在直下地狱。 我也要与时俱进了,被itpub2.0牵着尾巴,拼命的奔跑,不停的灌水...

Crystal Report动态分组

上一篇 / 下一篇  2008-02-13 17:28:29 / 个人分类:数据仓库专区

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

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

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
o`3u2U-R'\E~0as
C&y"~\L8sHc R0TYPE RefCursor IS REF CURSOR;
!lQ'Z!b(V5Z?&a.^$b0end;ITPUB个人空间f(vsM O D X/z
/

CREATEORREPLACEproceduregettabnopara(p_cursorinoutRefType.RefCursor)

as

begin

openp_cursorfor

selectowner,tablespace_name,table_name,1asTestNumber

fromall_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


TAG:

 

评分:0

我来说两句

显示全部

:loveliness: :handshake :victory: :funk: :time: :kiss: :call: :hug: :lol :'( :Q :L ;P :$ :P :o :@ :D :( :)

日历

« 2008-07-24  
  12345
6789101112
13141516171819
20212223242526
2728293031  

数据统计

  • 访问量: 18737
  • 日志数: 64
  • 建立时间: 2007-12-07
  • 更新时间: 2008-07-24

RSS订阅

Open Toolbar