1

我在 SQL Server 中有一个存储过程,它返回七个结果集。我想从 ASP.NET 调用这个存储过程,并在我的 ASP.NET 页面上用结果填充七个 GridView。我正在使用 SqlDataReader 来获取数据,但是我正在努力使用 C# 代码来填充 GridViews。

我创建了一个 DAL 类来获取数据,并且我有这个方法:

public SqlDataReader CheckDataIntegrity()
{
    SqlCommand cmd = new SqlCommand("cc.DataCheck");
    return MultipleResults(cmd);
}

辅助方法 MultipleResults 如下所示:

private SqlDataReader MultipleResults(SqlCommand cmd)
{
    SqlConnection con = new SqlConnection(_connectionString);
    cmd.Connection = con;

    con.Open();
    SqlDataReader dr = cmd.ExecuteReader();
    con.Close();
    return dr;

}

我正在尝试使用以下内容调用我页面上的组件:

private void FillGridViews()           
{
    DBUtil DB = new DBUtil();
    using (SqlDataReader dr = DB.CheckDataIntegrity())
    {
        if (dr.HasRows)
        {
            while (dr.Read())
            {
                GridView1.DataSource = dr;
                GridView1.DataBind();
            }
        }
    }
} 

我确实在网上搜索了一个这样的例子,但找不到任何东西。

你知道一个资源,或者有一个小例子可以分享吗?

谢谢。

4

2 回答 2

4

您应该使用可以将多个表绑定到您的 GridView 的 DataSet。

var dataset = GetDataSetForMy7GridViews();

// also valid: dataset.Tables["TableName"];
GridView1.DataSource = dataset.Tables[0]; 
GridView1.DataBind();

GridView2.DataSource = dataset.Tables[1];
GridView2.DataBind();

GridView3.DataSource = dataset.Tables[2];
GridView3.DataBind();

GridView4.DataSource = dataset.Tables[3];
GridView4.DataBind();

GridView5.DataSource = dataset.Tables[4];
GridView5.DataBind();

GridView6.DataSource = dataset.Tables[5];
GridView6.DataBind();

GridView7.DataSource = dataset.Tables[6];
GridView7.DataBind();

由于您要绑定到 7 个不同的 GridView,因此您需要这样做。如果您按照您的代码执行此操作:

>             while (dr.Read())
>             {
>                 GridView1.DataSource = dr;
>                 GridView1.DataBind();
>             }

它只会绑定到 1 个 GridView。

补充说:也许这个链接是你问题的答案? http://www.codeguru.com/csharp/csharp/cs_network/database/article.php/c8715

于 2010-11-18T12:16:13.167 回答
1

您需要使用 DataReader 的.NextResult() 方法从第一个结果集前进到下一个结果集。如果集合中存在更多结果,则该方法返回 True,如果不存在更多结果集,则返回 False。

调用 .NextResult() 后,您可以将 GridView 绑定到当前结果集。

您的代码可能如下所示:

SqlDataReader dr = DB.CheckDBIntegrity();

while (!dr.NextResult())
    {
       // bind results to appropriate grid
    }
于 2010-11-18T12:15:20.810 回答