C# 如何从SqlDataReader读取多个结果集?
我有一个SP,我正试图从中返回2个结果集,在我的.cs文件中,我正在尝试以下操作: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
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会过早退出。