自定义报表开发说明.doc
《自定义报表开发说明.doc》由会员分享,可在线阅读,更多相关《自定义报表开发说明.doc(18页珍藏版)》请在三一办公上搜索。
1、自定义报表开发说明目录1.自定义报表的目的32.自定义报表的开发过程33.自定义报表的技术原理44.独立的报表设计方法65.程序对独立报表的调用实现126.报表的部署157.报表的现场修改171. 自定义报表的目的开发自定义报表的目的有以下几点:1、 实现报表和程序分离。分离的报表和程序的分离是实现自定义报表工作的最主要目的。程序和报表分离可以使得报表的设计工作、程序的开发工作、报表的部署工作、报表的修改工作和报表的测试工作各自独立分开的来进行。减少开发人员在报表上的工作量,实现报表设计的专业化分工。提高报表的开发效率和质量。2、 实现专业化的独立报表制作。报表设计工作的独立进行可以更好的实现
2、报表的专业化制作,原来每个报表的设计和制作都合并到了应用程序的开发过程中,由程序员各自来实现不同的报表。不同的程序员实现报表的方法不尽相同,研究新的报表类型要花不少时间,互相之间没有足够的时间来讨论总结各种报表的最佳实现方法。独立的专业化报表制作工作可以使得报表设计人员有大量的机会接触到不同类型的报表。随着报表制作经验的积累,可以有效总结出越来越多的不同类型报表的最优制作方法,形成有效的专业知识,提高公司开发报表的速度和可实现报表的广度。并且方便对报表进行独立测试,提高报表质量。3、 提高项目开发效率。报表和程序的独立,使得各自的工作方向更加专注。不但使得项目开发工作能够并行,节省开发时间,而
3、且使得各自的工作更容易深入,提高各自工作的攻关能力和工作质量。4、 方便部署。报表和程序分离后,各自部分能够独立更新。避免了更新报表也产生新的软件版本的问题。在报表更新后软件部分没有变化的情况下,可以单独发布报表版本。实现了项目产品的灵活部署和配置。5、 灵活的报表定制。不同用户的报表格式不尽相同,相同的业务数据在不同的用户那里会以不同的组织形式构成报表。而且用户的打印机型号更是多种多样。报表制作时使用的打印机型号和纸张可能是用户那里没有的,需要在用户那边进行报表样式的定制和打印效果的调试。以往这种调试只能由实施人员在现场反馈回开发团队,然后开发团队在看不到现场打印效果的情况下调整报表,不但交
4、互次数多也不便与保证报表效果。2. 自定义报表的开发过程自定义报表的开发过程遵循软件工程的过程:1、 需求调研需求人员从用户处获得报表需求,包括报表的尺寸、样式、显示哪些数据、数据的类型、数据的格式、打印的份数和打印机的类型等等。需求人员提交报表需求时应详述报表细节,如有可能则提供纸质报表样式。2、 报表设计设计人员根据需求人员提供的报表要求设计出报表的实际结构,生成独立的报表文件。设计人员根据报表需求和完成的报表文件,进行报表的单元测试。设计人员需要模拟用户数据绑定到报表,查看打印预览并打印实际报表,将打印结果与提交的报表需求进行对比,确认报表文件可以满足用户需求。然后提交设计结果。3、 报
5、表接口开发及调用程序员根据报表需求的数据结构要求开发获得报表数据的代码。然后开发将封装的报表数据与指定报表文件绑定的方法。指定的报表文件名称可以从本地配置文件或数据库应用配置表中得到。程序员应对完成的程序进行单元测试确保程序能够将数据绑定到报表,并且能够成功的调用报表预览和打印。4、 报表的测试测试人员根据报表需求和设计人员提交的报表文件,进行报表测试。测试人员需要在应用软件环境中模拟用户数据绑定到实际报表,查看打印预览并打印实际报表,将打印结果与提交的报表需求进行对比,确认报表文件可以满足用户需求,记录测试通过,通知报表设计人员提交报表文件版本到配置管理。或者及时通知程序员或报表设计人员修改
6、相关缺陷。5、 报表部署配置管理员将最新提交的报表文件发布给实施人员。实施人员拿到报表文件后在用户环境中进行测试。确认无误后将报表文件安装到用户的客户机或服务器。3. 自定义报表的技术原理水晶报表程序控制上有两种模式,也就是PULL模式和PUSH模式。口语化点就是拉模式和推模式。拉(PULL)模式:由水晶报表模板(引擎)直接连接数据库(源),从数据库(源)里拉取数据。就是我们在水晶报表里设置好数据库信息,以及相关的表。当我们在程序中调用水晶报表引擎,挂载模板后,水晶报表引擎会根据模板里的数据库信息,及表信息主动连接数据库,返回数据给报表模板,模板根据设计样式进行呈现。基本流程如下图所示推(PU
7、SH)模式:由应用程序从数据库(源)获取数据,然后把数据推送给水晶报表引擎。水晶报表本身不跟数据库进行交互。其基本流程图如下对比两个图,黑色的箭头表示我们要自己进行编码,蓝色的箭头表示是水晶报表与数据源的自动交互过程,不需编码。这样我们很容易看到,使用PUSH模式将会比PULL模式多了不少代码。而且因为PULL模式是直连数据库,比PUSH模式的先获取数据结果,然后推送给水晶报表少了一个过程。而中间结果集本身就占用系统资源。所以PULL模式比PUSH执行效率高。那么两者的差异就出来了1:PULL模式代码量少2:PULL模式执行效率高3:实际开发过的朋友也有体会,使用PULL模式,模板开发的速度也
8、比PUSH模式模板简单一些这几点上,似乎PULL模式已经完全把PUSH模式打败了,那么为什么 PUSH模式还存在,且被大量使用呢?我们再返回去看上面两个示意图,大家注意到PULL模式中,是由水晶报表连接的数据库,也就是说,水晶报表引擎单独占用了一个数据库连接。而只有在水晶报表对象释放后,数据库连接才会释放(这个时段对系统时间来说,是比较长的,特别是如果要翻页等需要长时间连接数据库的情况)。而在PUSH模式中,数据库是由应用程序去连接的,水晶报表本身不连接数据库。这样,系统就能使用公用的数据库连接。这样一来,就节约了数据库的连接消耗。这一点,在多用户的系统环境内,少一次数据库连接对系统性能的影响
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 自定义 报表 开发 说明
链接地址:https://www.31ppt.com/p-4089124.html