首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >实体框架6中具有多个记录集的存储过程

实体框架6中具有多个记录集的存储过程
EN

Stack Overflow用户
提问于 2021-11-10 19:27:54
回答 1查看 804关注 0票数 1

ASP.NET Core6WebAPI,EF 6,C#,Server 2019。我知道如何执行返回记录集的存储过程,利用模型映射,并获得与记录对应的已填充强类型对象的集合。那样的话,生活是美好的。

是否有方法执行返回多个记录集并接收强类型记录对象集合集合的存储过程?

我知道如何使用实体框架(例如,使用旧式的SqlDataAdapter / Dataset,或者通过带有手工解析记录的DataReader )。

也许有一种方法可以将记录集解析逻辑从EF中的查询执行逻辑中分离出来,后者是否手工完成,然后从DataReaders序列中填充记录集合?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-11-10 19:45:20

如果您只需要将查询结果映射到对象,则不需要像EF 6这样功能齐全的ORM,您可以使用类似于脱衣舞的微ORM将查询结果直接映射到对象。

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

代码语言:javascript
复制
var sql="select * from Products where CategoryId=@category";
var products=connection.Query<Product>(sql,new {category=123});

您还可以映射多个结果:

代码语言:javascript
复制
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();
   ...
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69919157

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档