扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
作者:BipinJoshi/webabcd编译 来源:天极社区 2007年9月2日
关键字: ASP.NET ReportViewer 控件
在本页阅读全文(共19页)
介绍
任何数据驱动型的应用程序都有一个普遍的需求,那就是报表。但是,在ASP.NET 1.x中并没有给我们提供这个非常重要的特性。然而很幸运的是,伴随着.NET 2.0而来的ReportViewer控件可以满足你对报表的一些基本需求。我将会在本文中向你演示如何使用这个控件。ReportViewer控件既可以在web程序中使用,也可以在windows程序中使用。在这里,我将只介绍如何在web程序中使用它。
报表示例
我们假设要生成一个如下所示的顾客信息列表:
图1 |
上面的报表是一个非常简单的以国家分组的顾客信息列表。报表的数据是从Northwind数据库的Customers表里获取的。默认情况下,它会显示所有的顾客信息。但是,你也可以让它显示属于你指定的某个国家的顾客信息。
该报表是使用ReportViewer控件设计的,它可以从强类型的DataSet中或者自定义的对象集合中获取数据。在实际的程序开发中,我们往往会使用3层架构,数据的获取经常会是从业务层取得的DataSet或一个泛型集合。在这里,我打算使用一个泛型集合作为数据源,而不是强类型的DataSet。
创建类库
首先,打开Visual Studio,然后创建一个名为ReportViewerLib的类库项目。添加一个如下所示的名为Customer的类:
|
Customer类定义了四个公共属性,即CustomerID、CompanyName、ContactName和Country。在之后,是这个类包含的两个静态方法–GetCustomersForContry()和GetAllCustomers()。这两个方法都是比较简单的,一个是返回属于某一个国家的所有顾客信息,另一个是返回全部顾客信息。首先打开Northwind数据库的连接,然后通过SqlCommand对象执行SELECT查询。之后,用SqlDataReader对象来获取数据。遍历这个SqlDataReader对象,在其内每次都创建一个Customer对象,然后设置它的各个属性,最后把其添加到Customer对象的泛型集合中。在类的结尾处就是把这个Customer对象的泛型集合返回给调用者。
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。
现场直击|2021世界人工智能大会
直击5G创新地带,就在2021MWC上海
5G已至 转型当时——服务提供商如何把握转型的绝佳时机
寻找自己的Flag
华为开发者大会2020(Cloud)- 科技行者