2011-05-18 28 views

回答

3

如果使用DataReader检索数据,则可以使用NextResult方法遍历存储过程返回的多个结果集。更多信息可以发现here. 下面的代码是从MSDN一个简单的例子:

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(); 

     while (reader.HasRows) 
     { 
      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)); 
      } 
      reader.NextResult(); 
     } 
    } 
} 

如果是填充自DataAdapter的数据集,注意,如果的DataAdapter遇到多个结果,它会创建多个数据表(一个用于每个结果集)并将它们添加到结果数据集中。

相关问题