繁体   English   中英

从实体框架生成的数据库上下文中调用存储过程

[英]Calling Stored Procedure from Database Context generated by Entity Framework

目标

我正在使用C#+ MVC 4 + MySQL,我想在控制器中调用由Entity Framework 5创建的方法来调用存储过程。

问题

我不知道如何在我的控制器中调用以下方法,由Entity Framework在.Context.cs文件中创建:

public virtual ObjectResult<getProductsListForHome_Result> getProductsListForHome(Nullable<int> inOffer, Nullable<int> categoryId)
{
    var inOfferParameter = inOffer.HasValue ?
        new ObjectParameter("inOffer", inOffer) :
        new ObjectParameter("inOffer", typeof(int));

    var categoryIdParameter = categoryId.HasValue ?
        new ObjectParameter("categoryId", categoryId) :
        new ObjectParameter("categoryId", typeof(int));

    return ((IObjectContextAdapter)this).ObjectContext.ExecuteFunction<getProductsListForHome_Result>("getProductsListForHome", inOfferParameter, categoryIdParameter);
}

我有的

我已经试过了:

//
// GET: /Products/
public ActionResult Index()
{
    IEnumerable<getProductsListForHome_Result> products = db.getProductsListForHome(1, 14);

    var test = string.Join(",", (object[])products.ToArray());

    return Content(test);
}

当我访问/ Products /(产品的Controller的Index()方法)时 ,我看到一个空白页面: MyApp.Models.getProductsListForHome_Result

所以我问:我该怎么办?

将退货内容更改为退货视图。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM