在实体框架数据库优先方法中,如何从存储过程返回多个结果集?
Posted
技术标签:
【中文标题】在实体框架数据库优先方法中,如何从存储过程返回多个结果集?【英文标题】:In Entity Framework database-first approach how to return multiple result sets from a stored procedure? 【发布时间】:2015-05-27 08:27:08 【问题描述】:我正在使用数据库优先方法使用实体框架。我在 mysql 中创建了一个存储过程,它返回多个集合,我想一次获取所有结果集,而不仅仅是顶部的一个结果集。
在我的存储过程中,我也在传递参数。
【问题讨论】:
我同时使用 Mysql 和 Sql 。它必须在两者上运行。我知道在 mysql 中我必须通过 edmx 更新我的 ssdl 文件。 【参考方案1】:您可以使用 SQLQuery 来执行您的过程:
public partial class NorthwindContext
public IEnumerable<CustomerOrderHistory> CustomerOrderHistory(string customerID)
var customerIDParameter = customerID != null ?
new SqlParameter("@CustomerID", customerID) :
new SqlParameter("@CustomerID", typeof(string));
return Database.SqlQuery<CustomerOrderHistory>("CustOrderHist @CustomerID", customerIDParameter);
模型看起来像:
public partial class CustomerOrderHistory
public string ProductName get; set;
public Nullable<int> Total get; set;
这是基于 Northwind 数据库的示例
【讨论】:
这并不像 OP 所问的那样解决多个记录集。 这是否意味着返回不同的对象列表?还是返回自定义对象列表? 我认为 OP 在存储过程中有两个 select 语句。 但是需要与对象映射,你的解决方案没有使用EF,我知道如果想映射到不同的实体不能使用EF 我之前确实遇到过这个问题,经过研究我使用 ado.net 返回数据集作为替代方案。【参考方案2】:使用基本阅读器并使用reader.NextResult
方法。
var cmd = db.Database.Connection.CreateCommand();
cmd.CommandText = "some command here";
try
db.Database.Connection.Open();
var reader = cmd.ExecuteReader();
var books = ((IObjectContextAdapter)db)
.ObjectContext
.Translate<Book>(reader, "Books", MergeOption.AppendOnly);
// Move to second result set and read authors
reader.NextResult();
var authors = ((IObjectContextAdapter)db)
.ObjectContext
.Translate<Author>(reader, "Authors", MergeOption.AppendOnly);
finally
db.Database.Connection.Close();
【讨论】:
以上是关于在实体框架数据库优先方法中,如何从存储过程返回多个结果集?的主要内容,如果未能解决你的问题,请参考以下文章