科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道应用软件使用ASP.NET 2.0中的ReportViewer控件(1)

使用ASP.NET 2.0中的ReportViewer控件(1)

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

ASP.NET的ReportViewer控件提供了很多报表的基本功能。在本文中,我们使用了对象数据源控件来开发一个报表。我们创建了一个类库和一个数据源。最后使用ReportViewer控件来显示报表。

作者: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的类:

using System;

using System.Data;

using System.Configuration;

using System.Data.SqlClient;

using System.Collections.Generic;

namespace ReportViewerLib

{

 public class Customer

 {

public string strCustomerID;

public string strCompanyName;

public string strContactName;

public string strCountry;

public string CustomerID

{

 get

 {

return strCustomerID;

 }

 set

 {

strCustomerID = value;

 }

}

public string CompanyName

{

 get

 {

return strCompanyName;

 }

 set

 {

strCompanyName= value;

 }

}

public string ContactName

{

 get

 {

return strContactName;

 }

 set

 {

strContactName= value;

 }

}

public string Country

{

 get

 {

return strCountry;

 }

 set

 {

strCountry= value;

 }

}

public static List<Customer> GetCustomersForCountry(string country)

{

 SqlConnection cnn=new SqlConnection(

 ConfigurationManager.ConnectionStrings["NorthwindConnectionString"].ConnectionString);

 SqlCommand cmd=new SqlCommand();

 cmd.Connection=cnn;

 cmd.CommandText="select

 CustomerID,CompanyName,ContactName,Country

from customers where country=@country";

 SqlParameter p=new SqlParameter

("@country",country);

 cmd.Parameters.Add(p);

 cnn.Open();

 SqlDataReader reader = cmd.ExecuteReader();

 List<Customer> list = new List<Customer>();

 while (reader.Read())

 {

Customer c = new Customer();

c.CustomerID = reader.GetString(0);

c.CompanyName = reader.GetString(1);

c.ContactName = reader.GetString(2);

c.Country = reader.GetString(3);

list.Add(c);

 }

 cnn.Close();

 return list;

}

public static List<Customer> GetAllCustomers()

{

 SqlConnection cnn = new SqlConnection(

ConfigurationManager.ConnectionStrings

["NorthwindConnectionString"].ConnectionString);

 SqlCommand cmd = new SqlCommand();

 cmd.Connection = cnn;

 cmd.CommandText = "select

 CustomerID,CompanyName,ContactName,Country from customers";

 cnn.Open();

 SqlDataReader reader = cmd.ExecuteReader();

 List<Customer> list = new List<Customer>();

 while (reader.Read())

 {

Customer c = new Customer();

c.CustomerID = reader.GetString(0);

c.CompanyName = reader.GetString(1);

c.ContactName = reader.GetString(2);

c.Country = reader.GetString(3);

list.Add(c);

 }

 cnn.Close();

 return list;

}

 }

}

Customer类定义了四个公共属性,即CustomerID、CompanyName、ContactName和Country。在之后,是这个类包含的两个静态方法–GetCustomersForContry()和GetAllCustomers()。这两个方法都是比较简单的,一个是返回属于某一个国家的所有顾客信息,另一个是返回全部顾客信息。首先打开Northwind数据库的连接,然后通过SqlCommand对象执行SELECT查询。之后,用SqlDataReader对象来获取数据。遍历这个SqlDataReader对象,在其内每次都创建一个Customer对象,然后设置它的各个属性,最后把其添加到Customer对象的泛型集合中。在类的结尾处就是把这个Customer对象的泛型集合返回给调用者。

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章