【问题标题】: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 文件。

标签: c# mysql sql-server entity-framework stored-procedures


【解决方案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(); 
} 

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2017-01-10
    • 2021-04-08
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-08-06
    相关资源
    最近更新 更多