- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
自定义报表开发说明
目录
TOC \o 1-3 \h \z \u 1. 自定义报表的目的 3
2. 自定义报表的开发过程 3
3. 自定义报表的技术原理 4
4. 独立的报表设计方法 6
5. 程序对独立报表的调用实现 12
6. 报表的部署 15
7. 报表的现场修改 17
自定义报表的目的
开发自定义报表的目的有以下几点:
实现报表和程序分离。分离的报表和程序的分离是实现自定义报表工作的最主要目的。程序和报表分离可以使得报表的设计工作、程序的开发工作、报表的部署工作、报表的修改工作和报表的测试工作各自独立分开的来进行。减少开发人员在报表上的工作量,实现报表设计的专业化分工。提高报表的开发效率和质量。
实现专业化的独立报表制作。报表设计工作的独立进行可以更好的实现报表的专业化制作,原来每个报表的设计和制作都合并到了应用程序的开发过程中,由程序员各自来实现不同的报表。不同的程序员实现报表的方法不尽相同,研究新的报表类型要花不少时间,互相之间没有足够的时间来讨论总结各种报表的最佳实现方法。独立的专业化报表制作工作可以使得报表设计人员有大量的机会接触到不同类型的报表。随着报表制作经验的积累,可以有效总结出越来越多的不同类型报表的最优制作方法,形成有效的专业知识,提高公司开发报表的速度和可实现报表的广度。并且方便对报表进行独立测试,提高报表质量。
提高项目开发效率。报表和程序的独立,使得各自的工作方向更加专注。不但使得项目开发工作能够并行,节省开发时间,而且使得各自的工作更容易深入,提高各自工作的攻关能力和工作质量。
方便部署。报表和程序分离后,各自部分能够独立更新。避免了更新报表也产生新的软件版本的问题。在报表更新后软件部分没有变化的情况下,可以单独发布报表版本。实现了项目产品的灵活部署和配置。
灵活的报表定制。不同用户的报表格式不尽相同,相同的业务数据在不同的用户那里会以不同的组织形式构成报表。而且用户的打印机型号更是多种多样。报表制作时使用的打印机型号和纸张可能是用户那里没有的,需要在用户那边进行报表样式的定制和打印效果的调试。以往这种调试只能由实施人员在现场反馈回开发团队,然后开发团队在看不到现场打印效果的情况下调整报表,不但交互次数多也不便与保证报表效果。
自定义报表的开发过程
自定义报表的开发过程遵循软件工程的过程:
需求调研 需求人员从用户处获得报表需求,包括报表的尺寸、样式、显示哪些数据、数据的类型、数据的格式、打印的份数和打印机的类型等等。需求人员提交报表需求时应详述报表细节,如有可能则提供纸质报表样式。
报表设计 设计人员根据需求人员提供的报表要求设计出报表的实际结构,生成独立的报表文件。设计人员根据报表需求和完成的报表文件,进行报表的单元测试。设计人员需要模拟用户数据绑定到报表,查看打印预览并打印实际报表,将打印结果与提交的报表需求进行对比,确认报表文件可以满足用户需求。然后提交设计结果。
报表接口开发及调用 程序员根据报表需求的数据结构要求开发获得报表数据的代码。然后开发将封装的报表数据与指定报表文件绑定的方法。指定的报表文件名称可以从本地配置文件或数据库应用配置表中得到。程序员应对完成的程序进行单元测试确保程序能够将数据绑定到报表,并且能够成功的调用报表预览和打印。
报表的测试 测试人员根据报表需求和设计人员提交的报表文件,进行报表测试。测试人员需要在应用软件环境中模拟用户数据绑定到实际报表,查看打印预览并打印实际报表,将打印结果与提交的报表需求进行对比,确认报表文件可以满足用户需求,记录测试通过,通知报表设计人员提交报表文件版本到配置管理。或者及时通知程序员或报表设计人员修改相关缺陷。
报表部署 配置管理员将最新提交的报表文件发布给实施人员。实施人员拿到报表文件后在用户环境中进行测试。确认无误后将报表文件安装到用户的客户机或服务器。
自定义报表的技术原理
水晶报表程序控制上有两种模式,也就是PULL模式和PUSH模式。口语化点就是拉模式和推模式。
拉(PULL)模式:
由水晶报表模板(引擎)直接连接数据库(源),从数据库(源)里拉取数据。就是我们在水晶报表里设置好数据库信息,以及相关的表。当我们在程序中调用水晶报表引擎,挂载模板后,水晶报表引擎会根据模板里的数据库信息,及表信息主动连接数据库,返回数据给报表模板,模板根据设计样式进行呈现。
基本流程如下图所示
推(PUSH)模式:
由应用程序从数据库(源)获取数据,然后把数据推送给水晶报表引擎。水晶报表本身不跟数据库进行交互。
其基本流程图如下
对比两个图,黑色的箭头表示我们要自己进行编码,蓝色的箭头表示是水晶报表与数据源的自动交互过程,不需编码。
这样我们很容易看到,使用PUSH模式将会比PULL模式
原创力文档


文档评论(0)