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

存储过程的结果集是指存储过程执行后返回的一组或多组查询数据。当存储过程中包含多个SELECT语句时,每个SELECT都会生成一个独立的结果集。这些结果集按顺序返回给调用程序。
在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 就能完整提取所有信息。
以上就是什么是存储过程的结果集?在C#中如何读取多个结果集?的详细内容,更多请关注php中文网其它相关文章!
 
                        
                        每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
 
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号