答案:在C#中通过SqlDataReader的NextResult()方法可依次读取存储过程返回的多个结果集。首先执行存储过程获取SqlDataReader,用Read()读取当前结果集数据,再调用NextResult()移动到下一结果集,重复此过程直至所有结果集处理完毕。示例代码展示了如何顺序读取Users和Orders两个结果集,需注意每个结果集必须完全读取后再调用NextResult(),若结果集数量未知可用循环持续调用NextResult()直到返回false,确保不遗漏任何数据。

存储过程的结果集是指存储过程执行后返回的一组或多组查询数据。当存储过程中包含多个select语句时,每个SELECT都会生成一个独立的结果集。这些结果集按顺序返回给调用程序。
如何在C#中读取多个结果集
在C#中使用 ADO.net 调用返回多个结果集的存储过程时,可以通过 SqlDataReader 逐个读取每个结果集。关键在于使用 NextResult() 方法移动到下一个结果集。
操作步骤与示例代码
假设有一个存储过程返回两个结果集:
CREATE PROCEDURE GetMultipleResults AS BEGIN SELECT Id, Name FROM Users; SELECT OrderId, UserId, Amount FROM Orders; END
在C#中读取这两个结果集的方法如下:
1. 执行命令并获取 SqlDataReader
使用 SqlCommand 执行存储过程,调用 ExecuteReader 得到 SqlDataReader。
2. 读取第一个结果集
通过 Read() 方法遍历第一组数据。
3. 移动到下一个结果集
调用 NextResult() 方法准备读取下一个结果集。
4. 读取后续结果集
继续使用 Read() 遍历后续数据。
using (var connection = new SqlConnection(connectionString)) { connection.Open(); using (var cmd = new SqlCommand("GetMultipleResults", connection)) { cmd.CommandType = CommandType.StoredProcedure; using (var reader = cmd.ExecuteReader()) { // 读取第一个结果集 Console.WriteLine("Users:"); while (reader.Read()) { Console.WriteLine($"ID: {reader["Id"]}, Name: {reader["Name"]}"); } // 移动到第二个结果集 if (reader.NextResult()) { Console.WriteLine("Orders:"); while (reader.Read()) { Console.WriteLine($"Order ID: {reader["OrderId"]}, Amount: {reader["Amount"]}"); } } } } }
注意事项
确保每次调用 NextResult() 前当前结果集已完全读取,否则可能丢失数据或引发异常。如果不确定结果集数量,可用循环持续调用 NextResult() 直到返回 false。
基本上就这些。处理多个结果集不复杂,但要小心别漏掉中间的数据集。正确使用 Read 和 NextResult 就能完整提取所有信息。


