学生信息报表系统的实现

上传人:bao****ty 文档编号:117265894 上传时间:2019-12-05 格式:DOC 页数:34 大小:1.94MB
返回 下载 相关 举报
学生信息报表系统的实现_第1页
第1页 / 共34页
学生信息报表系统的实现_第2页
第2页 / 共34页
学生信息报表系统的实现_第3页
第3页 / 共34页
学生信息报表系统的实现_第4页
第4页 / 共34页
学生信息报表系统的实现_第5页
第5页 / 共34页
点击查看更多>>
资源描述

《学生信息报表系统的实现》由会员分享,可在线阅读,更多相关《学生信息报表系统的实现(34页珍藏版)》请在金锄头文库上搜索。

1、学生信息报表系统的实现本章将基于一个比较简单的学生信息报表系统来介绍VS.NET中的水晶报表的使用方法。报表也是一种管理工具,其目的在于帮助用户快速掌握原始数据中的基本元素和关系,以便于工作进行有效的决策。VB.NET中的水晶报表(Crystal Reports)是一个实现比较复杂但使用方法十分简单的报表生成工具,它提供了非常丰富的模型以使我们能够在运行时操作属性和方法,既可以嵌入到Windows应用程序中,也可以加入到ASP.NET的Web应用程序中。31 案例简介本案例完成的功能很简单:把数据库里的学生信息表和学院信息表中的数据用不同的水晶报表呈现出来。本例共实现了5张报表,分别从不同的侧

2、面体现了学生的信息和水晶报表的特点。除了显示报表,用户还可以通过界面向学生信息表和学院信息表中插入记录。通过刷新操作可以立刻将插入的记录显示在报表中。本案例是一个Windows应用程序,在主框体中嵌入了一个水晶报表察看器(CrystalReportViewer),用于察看不同的报表。另外,可以在界面上进行一些简单的对数据库的操作,通过水晶报表提供的刷新功能。本案例实现的是主从报表,学生信息表和学院信息表通过学院编号字段关联起来。图3-1是程序运行时的外观。在实现时使用的是push模式,将数据库中的数据绑定到一个数据集上,用报表专家根据数据集提供的数据设置水晶报表(.rtp文件)的样式、字段、图

3、表、公式的一系列属性,再将水晶报表察看器的数据源设成.rpt文件。整个程序的编码十分简单,所以本章讲解的重点并不在代码的实现,而是在操作的流程上。图3-1 学生信息报表系统32 水晶报表简介下面介绍一些水晶报表中将要用到的概念。(1) 水晶报表设计器水晶报表就是在设计器中创建的,在设计器中用户可以进行设计标题,插入数据、公式、图表、子报表等操作。(2) .rpt报表文件 执行报表中的第一步就是在水晶报表设计器接口创建此报表,在默认安装中微软已经提供了一些现成的.rpt例子。(3) 数据源 .rpt报表文件取得数据的方法有两种:让水晶报表自己选择数据而不使用任何代码,或者编写代码把一个DataS

4、et作为数据源绑定到.rtp报表文件。(4) 执行模式 水晶报表取数据可以使用下面的方法实现。Pull模式被请求时,水晶报表直接根据指定的驱动连接数据库然后组装这些数据,如图3-2所示;Push模式此时开发表不得不自己编写代码连接数据并安装DataSet,同时将它传送至报表。在这种情况下,通过使用连接共享以及限制记录集合的大小,可以使用报表性能最大化,如图3-3所示。水晶报表数据库图3-2 pull模式水晶报表数据集数据库RDDDAOADOCDOADO.NET图3-3 push模式(5) 报表类型 水晶报表设计器能够直接包含报表至工程,也能够使用独立的报表对象。(6) Strongly-typ

5、ed报表 当将报表文件加入到项目中去时,它就变成一个Strongly-typed报表。在这种情况下,用户将拥有直接创建报表对象的权力,这将减少一些代码并且能够提升一些性能。(7) Un-Typed报表 报表并不直接包含在项目中,称为un-typed报表。在这种情况下,用户要使用水晶报表的ReportDocuemt对象建立一个实例,并且手动调用报表。为了让用户对水晶报表有一个感性的认识,下面的图3-4和图3-5展示了两张水晶报表图片。例1中使用的数据是SQL Sever中自带的,图中显示的是一个主从报表,是数据库中的两个表通过一个字段关联起来,在一个报表中显示两张数据库表中的相关数据。图3-4

6、水晶报表例1例2中使用的报表是微软的.NET平台自带的.rpt文件,通过在工程中添加这个文件并绑定到CrystalReportViewer控件上就可以显示了。图3-5 水晶报表例2水晶报表的优点在于:它能够进行快速的报表开发;能够导出成为复杂的交互性图表;可以与其他控件一起在WebForm、WinForm中使用;能够动态地将报表导出成为.pdf,doc,xls,html,rtf等多种格式;自带了刷新、翻页、放大缩小、查找和定位功能。33 应用程序概述本应用程序分为两个模块,分别为显示水晶报表模块和数据库录入模块。显示水晶报表模块由两大控件组成:一个crystalReportViewer和一个c

7、omboBox。crystalReportViewer用于显示水晶报表的内容,包括图和表,它具有一些自带的功能:翻页、挑转向某一页、关闭当前视图、打印报表、切换组树、放大缩小和查找功能。是现代战争功能十分强大的控件。其中的导出报表功能可以将报表导出为.xls、.doc以及.rtf等格式。在comboBox中选择需要显示的报表种类,就会在crystalReportViewer看到相应的报表。在本案例的实现中使用了5张水晶报表,分别从不同的侧面反映学生信息。数据库录入模块又分为两个部分:学院信息录入和学生信息录入。学院信息包括学院编号、学院名称、院长姓名和对学院的描述:学生信息包括学号、姓名、年龄

8、。所在学院编号。除了对学院的描述信息以外其他的信息在录入数据库时不能为空。否则系统会报错。编写本案例的目的在于教会用户怎样使用水晶报表,体会水晶报表的强大功能。在下面的方案设计中将结合本案例讲解水晶报表的一些使用方法。34 方案设计本系统运行在Windows 2000或者Windows XP之上,整个程序由前台的界面部分和后台的数据库部分组成,显示报表时程序从数据库中取出数据,反映在报表中,同时用户可以从界面对数据库进行插入记录的操作。从而实现了一个交互的过程。前台的界面部分在.NET平台上用C#语言实现,后台连接的数据库是为SQL Server 2000。3.4.1 应用程序的结构前台的整个

9、程序由一个.xsd文件、7个.cs文件和5个.rpt文件组成。其中的.xsd文件是C#中的ADO.NET数据集文件,数据集用于在断开缓存数据,它的结构类似于关系数据库的结构;它公开表、行和列的分层对象模型。另外,它包含为数据集定义的约束和关系。数据集是容器,因此需要用数据填充它。在下面的实现部分会讲解数据集的填充方法。AssemblyInfo.cs文件在创建解决方案时由系统自动生成,包含了一些与程序编译运行有关的属性集,Student.cs文件中定义了程序的主窗体类,程序的代码都添加在这个文件中。其他5个.cs文件都是程序为各个水晶报表自动生成的,不需要用户进行修改。剩下的5个.rpt文件,它

10、们分别是学生基本信息表、学院基本信息表、学生人数对比1、学生平均年龄对比和学生人数对比2。每一个文件对应了程序中的一张报表,通过使用报表设计器和报表专家来对这些报表 的内容和形式进行编辑,最后,为了达到用户的要求还要手工对报表作一些调整。3.4.2 数据库设计根据本系统的功能要求以及功能模块的划分,数据需要存储的信息如下:l 所有学生的基本信息:学号、姓名、年龄、所在学院编号等。l 所有学院的基本信息:学院编号、学院名称、院长姓名和对学院的描述信息等。由于本程序中对数据库的操作较为简单,所以没有加入存储过程。下面分别介绍数据库表的设计方案。 1.Students表Students表用于记录学生

11、的一些基本信息:学号、姓名、年龄、所在学院编号,另外还包括一个Stu_ID字段,它的值由数据库以递增的方式自动生成。对学生信息的要求是不能在此表中出现Department表中没有出现的学院的学生。对这一条件的控制将在程序代码中进行。这个表中所有的字段都不允许为空。表的各个字段的详细说明如图3-6所示。图3-6 Students表创建该表的脚本语言如下:CREATE TABLE Students (Stu_ID int IDENTITY (1, 1) NOT NULL ,Stu_Number nvarchar (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,St

12、u_Name nvarchar (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,Stu_Age int NOT NULL ,Dep_Number int NOT NULL ,CONSTRAINT PK_Students PRIMARY KEY CLUSTERED (Stu_Number) ON PRIMARY ) ON PRIMARYGO2.Department表Department表用于记录学院的基本信息学院编号、学院名称、院长姓名和对学院的描述信息。同时也包括一个Dep_ID字段,它的值由数据库以递增的方式自动生成。本表中除了学院的描述信息外,其他字段都是

13、不能为空的。表的各个字段详细说明如图3-7所示。图3-7 Department表创建该表的脚本语言如下:CREATE TABLE Department (Dep_ID int IDENTITY (1, 1) NOT NULL ,Dep_Number int NOT NULL ,Dep_Name nvarchar (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,Dep_Head nvarchar (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,Dep_Des nvarchar (200) COLLATE Chinese_PRC_

14、CI_AS NULL ,CONSTRAINT PK_Department PRIMARY KEY CLUSTERED (Dep_Number) ON PRIMARY ) ON PRIMARYGO这两个表通过Dep_Number字段相关联。在下面的程序实现中将会通过这个字段对这两个表进行联表操作。35方案实现本节将详细地介绍.NET平台下C#语言中的水晶报表的使用方法。本案例实现的执行模式是push模式,这种模式需要自己编写代码连接数据并组装DataSet,同时将它传送至报表。下面将按照程序实现的步骤一步一步地详细讲解具体的操作和程序代码,最后展示程序运行的结果。3.5.1添加数据集文件首先,在

15、新建的一个Windows应用程序中添加一个数据集文件,如图3-8所示。命名为Dataset1.xsd。ADO.NET数据集是以XML形式表示的数据视图,它是一种数据关系视图。在Visual Studio和.NET框架中,XML是用于存储和传输各种数据时所用的格式。数据集在断开的缓存中存储数据。数据集的结构类似于关系数据库的结构,它公开表、行和列的分层对象模型。图3-8 添加数据集单击“打开”按钮后进入的页面如图3-9所示。图3-9 Dataset1.xsd单击界面上的“服务器资源管理器”链接,编辑器的左边将会出现服务器资源管理界面,在服务器资源管理中,右击“数据连接”并在弹出的菜单中选择“添加连接”命令,弹出“数据链接属性”对话框。在“数据链接属性”对话框中,选择提供程序项卡,选择一个提供程序Cicrosoft OLE DB Provider for

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 大杂烩/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号