在实体框架数据库优先方法中,如何从存储过程返回多个结果集?

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(); 
 

【讨论】:

以上是关于在实体框架数据库优先方法中,如何从存储过程返回多个结果集?的主要内容,如果未能解决你的问题,请参考以下文章

如何在实体框架中定义存储过程(代码优先)?

具有实体框架问题的 Informix 存储过程

实体框架 - 具有多个结果集的存储过程 - 没有行返回

在实体框架中使用存储过程(代码优先)

使用实体框架核心生成和访问存储过程

如何在实体框架代码优先方法中使用表值函数?