转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 软件开发 >> Delphi程序 >> 正文
rave report的使用感想         ★★★★

rave report的使用感想

作者:闵涛 文章来源:闵涛的学习笔记 点击数:868 更新时间:2009/4/23 18:26:20

上个礼拜,公司签了一个新客户,他们要求在我们在summary报表假如更多的交易类型。我们的系统采用的是rave4.0,报表的layoutrave文件)存放在数据库中,使用时,用存储过程获取数据,然后填充到报表文件中,用户就可以浏览打印。整个过程很简单,可没想到,这就是我恶梦的开始。

首要的问题,是这个报表原始设计一塌糊涂,有大量的运算不是在存储过程中完成,而是在report里完成,而rave4.0提供的运算符功能极其简单,只能支持二元运算,稍微复杂一点的运算表达式都会牵连出一大堆的中间运算符和临时参数。当初的设计者把所有的参数都设成为project parameters,而且命名毫无规则可言,使得整个运算逻辑表达得像一锅粥。打个比方,我在报表的底部看到一个AdjustdeValue的显示字段,一看属性,是来自一个叫做AdjustedValuePG1的参数,但是这个参数是怎么算出来的呢?你不知道,你只知道它是一个project parameter,好,这就是说,我得浏览项目中的所有运算符的destination parameter,运气好的话,找个十几二十次就能找到,找到以后才是第一步,因为这个运算符的两个运算元素又是两个参数,好,继续重复第一步,就这样,重复在整个报表项目里scroll了半个小时,你发现原来这个adjustedValue是来自于一个5个变量的四则混合运算表达式。这算是运气好的,但是rave还提供了在程序里设置这些参数值的函数,比方说,我发现一个temp1的参数,我遍历了大大小小100多个运算符不止一次以后,终于发现原来这个参数是在程序里面设定的。虽然说这个设计问题主要责任在当初的设计人员身上,但是rave4.0小儿科的运算功能和及其简易的内部结构也是一个重要诱因。 

其次,rave4.0的界面非常不好用,最简单的例子就是,在对象属性框里居然不支持Ctrl+CCtrl+P,简直荒谬。而且,整个界面无法体现出个个元素之间的关系,也没有提供能够快速访问相关元素的功能,所有的浏览只能手动在整个项目结构书中一点一点寻找。

在花了3天时间搞清楚了大部分运算逻辑以后,我决定把整个report推倒重来。这是我第一次从头设计报表,但是经过这段时间的琢磨,我觉得报表设计需要遵循几个原则。

1. 我认为rave只适合做纯粹的格式控制,所有的数据都必须在调用报表之前准备好。(事实上,我认为所有的报表设计都应该这么做,必须用某种方式把运算逻辑和格式控制分离,否则,一旦需要更换报表组件或者调整运算逻辑,后继人员将会花费大量的时间来pick up

2. 元素命名一定要遵循某个统一规范,这个更是软件开发各个环节需要遵循的一大基本规则,基本上,在这一条上屡教不改者,就可以考虑直接fire了。因为这种人在团队中待的时间越长,给整个团队开发带来的危害就越大。

3. 报表要具备一定的扩充能力,像我对付的那个报表,因为当初只支持两个类型,竟然在所有求和的运算中都用加法运算符代替了求和运算符,结果,一旦要增加一个新类型,就必须重做所有的求和运算。而事实上,如果能很好地做到第1部分,第3部分的是现实不费吹灰之力的,与在rave中相比,在程序代码或者存储过程中修改一下计算逻辑简直就是天堂里的工作。

我承认,这几天我遇到的问题不完全是rave的问题,里面有大量的原始设计问题,但是,rave仍然给我留下了很差的印象,我想,如果以后我有选择,我是不会再碰rave了。


[VB.NET程序]使用Data Report打印查询结果  [VB.NET程序]Crystal Report(水晶报表)的报表封装成VB的DLL
[VB.NET程序]实现listview控件report视图下任何列头的双向排序  [Delphi程序]使用 Crystal Report 9.2 制作报表模板
[Delphi程序]Rave Report中文版插件 V0.1  [Delphi程序]Delphi 7 中使用RAVE报表(一)
[Delphi程序]Delphi 7 中使用RAVE报表(二)  [Delphi程序]用Fast Report建立跨栏报表
[VB.NET程序]VB6中水晶报表(Crystal Report 4.6)的使用经验  [ORACLE]在Oracle iAS 10g中创建Report Server
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · C语言系列  · VB.NET程序
    · JAVA开发  · Delphi程序
    · 脚本语言
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台