Entity Framework 6 中具有多个记录集的存储过程

Stored procedure with multiple recordsets in Entity Framework 6

ASP.NET Core 6 Web API、EF 6、C#、SQL Server 2019。我知道如何执行 returns 记录集的存储过程,取利用模型映射,并获得与记录相对应的填充的强类型对象的集合。生活就是这样。

有没有办法执行 returns 多个记录集的存储过程并接收强类型记录对象集合的集合?

我知道如何做到这一点 sans Entity Framework(例如,旧学校 SqlDataAdapter / Dataset,或通过a DataReader 手动解析记录)。

也许有一种方法可以以某种方式将记录集解析逻辑与 EF 中的查询执行逻辑分离,手动执行后者,然后从一系列 DataReader 中填充记录集合?

如果您只需要将查询结果映射到对象,您不需要需要像 EF Core 6 这样的全功能 ORM。您可以使用像 Dapper 将查询结果直接映射到对象。

在最常见的情况下,您可以将查询结果映射到对象,甚至可以使用参数,例如:

var sql="select * from Products where CategoryId=@category";
var products=connection.Query<Product>(sql,new {category=123});

您还可以映射多个结果:

var sql =
@"
select * from Customers where CustomerId = @id
select * from Orders where CustomerId = @id
select * from Returns where CustomerId = @id";

using (var multi = connection.QueryMultiple(sql, new {id=selectedId}))
{
   var customer = multi.Read<Customer>().Single();
   var orders = multi.Read<Order>().ToList();
   var returns = multi.Read<Return>().ToList();
   ...
}