Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/.net/20.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 如何从SqlDataReader读取多个结果集?_C#_.net_Sqldatareader_Multiple Resultsets - Fatal编程技术网

C# 如何从SqlDataReader读取多个结果集?

C# 如何从SqlDataReader读取多个结果集?,c#,.net,sqldatareader,multiple-resultsets,C#,.net,Sqldatareader,Multiple Resultsets,我有一个SP,我正试图从中返回2个结果集,在我的.cs文件中,我正在尝试以下操作: dr = cmd.ExecuteReader(); while (dr.Read()) { RegistrationDetails regDetails = new RegistrationDetails() { FName = dr["FName"].ToString(), LName = dr["LName"].ToString(), MName = dr["MName"].T

我有一个SP,我正试图从中返回2个结果集,在我的.cs文件中,我正在尝试以下操作:

dr = cmd.ExecuteReader();
while (dr.Read())
{
  RegistrationDetails regDetails = new RegistrationDetails()
  {
    FName = dr["FName"].ToString(),
    LName = dr["LName"].ToString(),
    MName = dr["MName"].ToString(),
    EntityName = dr["EntityName"].ToString(),// in 2nd result set
    Percentage = dr["Percentage"].ToString()// in 2nd result set
   };
}
然而,我得到了一个:

错误:IndexAutoFrange{“EntityName”}


这里有一个关于如何使用数据读取器处理多个结果集的示例

static void RetrieveMultipleResults(SqlConnection connection)
{
    using (connection)
    {
        SqlCommand command = new SqlCommand(
          "SELECT CategoryID, CategoryName FROM dbo.Categories;" +
          "SELECT EmployeeID, LastName FROM dbo.Employees",
          connection);
        connection.Open();

        SqlDataReader reader = command.ExecuteReader();

        do
        {
            Console.WriteLine("\t{0}\t{1}", reader.GetName(0),
                reader.GetName(1));

            while (reader.Read())
            {
                Console.WriteLine("\t{0}\t{1}", reader.GetInt32(0),
                    reader.GetString(1));
            }               
        }
        while (reader.NextResult());
    }
}

从多个数据集中检索数据的关键是使用
reader.NextResult

刚刚遇到这个问题,最好在这里使用do{}while(reader.NextResult())。结果集可能为空,reader.HasRows将返回false。这不仅更好,而且是唯一正确的方法。请按照Neil M所说的进行相应的修复。简单地说,如果第一个结果集为空,而第二个结果集有结果,那么HasRows会过早退出。