关于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
获取用户拥有阅读权限所有的表。
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
,具体公式如下
5. 在报表中点击
Insert Group,选择
GroupBy,SubGroupBy
,插入分组栏目
6. 然后在
Group Footer#2,Group Footer#1中插入
Insert Summary
7. 最终报表的设计样式如下:
所有的报表相关参数参见
Field Explorer图,然后就
OK了
很多经验不敢独享,何况我也是踩着前人的臂膀才做出来的,说实话说到数据仓库工具我一向是眼高手低的,攻克这个所谓的技术问题,也算值得高兴一把。
有这样一个需求,假设有这么一张报表
用户可能要求按如下组合进行分组:
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; / |
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} |
Insert Group,选择
GroupBy,SubGroupBy
,插入分组栏目
6. 然后在
Group Footer#2,Group Footer#1中插入
Insert Summary
7. 最终报表的设计样式如下:
所有的报表相关参数参见
Field Explorer图,然后就
OK了
相关文章推荐
- 关于Crystal Report动态分组的使用
- 关于动态SQL的使用
- android 线程中的ui问题 Handler的基本使用 关于获取动态时间在ui的问题
- 转:关于GCC中同时使用动态和静态库链接的操作参数和解释
- 关于c中无法使用动态数组的简单解决办法
- 在VB中使用动态分组报表
- 关于动态添加自定义控件的使用心得
- 关于Swift使用UITabelView动态加载Cell(NSClassFromString使用问题)
- 关于使用ant-design设计可动态添加FormItem的过程中遇到的问题记录。
- 关于动态SQL的使用
- 转:关于GCC中同时使用动态和静态库链接的操作参数和解释
- 关于使用StickyDecoration分组错乱问题
- 关于如何使用EditText动态监测关键词
- 关于使用Jquery动态生成页面组件的时候,单引号和双引号的注意
- 关于android studio中使用class.forname()方法动态获取类实例报NO CLASS FOUND异常的几种处理方法
- Android 6.0 动态权限实战(二 - 终结章 - 高手必看!)------ 关于动态权限的正确使用与理解
- 关于easyUI datagrid、layout动态改变大小使用的方法
- 关于动态分配vector指针和使用shared_ptr的vector指针
- 关于使用EasyUI动态添加标签的个人笔记-V1
- 关于使用spring的动态代理机制时为什么必须指定接口