| « | 六月 2008 | » | ||||
|---|---|---|---|---|---|---|
| 一 | 二 | 三 | 四 | 五 | 六 | 日 |
| 1 | ||||||
| 2 | 3 | 4 | 5 | 6 | 7 | 8 |
| 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| 16 | 17 | 18 | 19 | 20 | 21 | 22 |
| 23 | 24 | 25 | 26 | 27 | 28 | 29 |
| 30 | ||||||
很多经验不敢独享,何况我也是踩着前人的臂膀才做出来的,说实话说到数据仓库工具我一向是眼高手低的,攻克这个所谓的技术问题,也算值得高兴一把。
有这样一个需求,假设有这么一张报表

用户可能要求按如下组合进行分组:
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 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了
