C数据交换与报表技术.pptxVIP

  • 2
  • 0
  • 约7.76千字
  • 约 39页
  • 2023-10-26 发布于境外
  • 举报
第10讲 数据交换与报表技术 (扩展内容);内容提要;课程导入 ;实现思路:使用COM组件实现。COM:Component Object Model (一)Word实现数据的显示与打印 【涉及知识】 引用Word动态链接库(Microsoft Word 11.0 Object Lib); 对象模型中Cell对象的应用; DataGridView控件的应用; Word的Application对象的应用; Word的Document对象的应用。;【设计目标】;;5/30/2021;5/30/2021;;5/30/2021;【设计目标】;;程序运行结果如图所示。;三、Crystal Report;VS提供两种报表设计模板: (1)微软报表:上图中名为“报表”或“报表向导”的模板,文件名后缀为“.rdlc”。用于设计在SQL Server报表服务器(Microsoft Reporting Service)上发布的服务器报表,与SQL Server的版本密切相关。(不讲,请参考相关资料) (2)水晶报表:上图中名为“Crystal Reports”的报表设计模板,文件名后缀为“.rpt”。集成于VS2003-VS2008版本,VS2010及以后的版本需要单独下载SAP Crystal Reports, version for Visual Studio 2010安装。设计、调用简单方便、通用性强。 ;(二)水晶报表基础知识;;2、嵌入式报表和非嵌入式报表不同点: ①嵌入式报表具有与.rpt文件对应的同名包装类,直接通过代码与包装类进行交互,而不是与原始报表文件本身进行交互。非嵌入式报表则单独以.rpt文件形式存在,该报表不包含在项目内,也没有对应的报表包装类。 ②对于嵌入式报表,系统对项目进行编译时,与其他项目资源一样,报表和其包装类都会被自动嵌入到程序集中,用户看不到被包装后的.rpt文件。对于非嵌入式报表,如果是ASP.NET网站,要求该.rpt文件保存在网站根目录下,如果是Windows应用程序则要求分发后.rpt文件保存在和.exe文件相同的目录下。 ③对于嵌入式报表,如果修改了报表内容,必须重新编译整个项目。修改非嵌入式报表不须重新编译整个项目。 ;3、相关操作 ①如何将报表设置为“嵌入式报表”和“非嵌入式报表”? 在【解决方案资源管理器】中,水晶报表.rpt文件的【生成操作】属性默认为“嵌入的资源”,即嵌入式报表。如果将其【生成操作】属性改为“无”,该报表即成为“非嵌入式报表”(此时需要将【复制到输出目录】属性改为“始终复制???,以便在程序中能够访问到该文件)。;;②对于“非嵌入式报表” 需要使用ReportDocument对象的Load方法将报表加载到ReportDocument对象模型中,然后用CrystalReportViewer Application.StartupPath对象的【ReportSource】属性将报表绑定到ReportDocument对象。 如:;(三)嵌入式水晶报表设计器;;(四)报表节 1) 报表头(Section1) 报表头节中的对象只在报表开头显示一次,一般在该节中放置希望只在整个报表开头出现的信息。 2) 页眉(Section2) 保存在页眉中的对象在每页的顶部位置都会显示。 3) 详细资料(Section3) 保存在详细资料中的对象在每条记录中都会显示。 4) 报表尾(Section4) 报表尾节中的对象只在报表的结束显示一次,一般在该节中放置希望只在整个报表结尾出现的信息。 5) 页脚(Section5) 保存在页脚中的对象在每页的底部都会显示。 6) 组页眉和组页脚(Section6) 组页眉和组页脚中的对象分别显示在每个新组的开始位置和结束位置。;(五)报表数据源 水晶报表数据源可以(1)直接连接到数据库、(2)使用ADO.Net数据集。建议尽量使用ADO.Net数据集(要现在项目中创建DataSet数据集.xsd对象)。 使用VS的ADO.NET数据集设计器,既可以从多种数据源(包括Access、Oracle和SQL Server数据库)创建ADO.NET数据集,也可以灵活、方便地控制报表的输出。 (六)水晶报表的对象模型 对象模型是指构成编程模型的核心类及其周围类。 分类: CrystalReportViewer对象模型 ReportDocument对象模型;1. CrystalReportViewer对象模型 CrystalReportViewer控件包含可用于控制该控件如何显示报表的属性和方法,以及少量的与绑定到该控件的报表进行交互的属性和方

文档评论(0)

1亿VIP精品文档

相关文档