4

我有一个返回 的 MVC4 WebAPI 控制器,IQueryable因此我可以$filter在 URL 中使用和朋友来操作来自 REST 端点的结果。这是我的控制器:

public class EnrollmentController : ApiController
{
    [Queryable]
    public IQueryable<tblEnrollment> Get()
    {
        var context = new ProjectEntities();
        context.ContextOptions.LazyLoadingEnabled = false;
        return context.tblEnrollment.AsQueryable();
    }
}

但是,就像这张海报一样,我想让 JSON 输出格式有点不同,以便与 Ember Data 的预期格式更友好。所以我想返回这个:

return new { enrollment = context.tblEnrollment.AsQueryable() }; 

但是,这会破坏 OData 功能,因为我没有返回IQueryable到 WebAPI 层。所以,我想知道是否有办法做这样的事情:

return new { enrollment = context.tblEnrollment.AsQueryable().ApplyOData() }; 

我敢肯定这会是真的……但是有什么方法可以显式地处理 OData 参数IQueryable而不是让 WebAPI 层在从Get方法返回的结果集上隐式地执行它?还是有另一种方法可以在这里完成我想要的?

顺便说一句,我暂时停留在 EF4 上,因为我无法升级到 VS2012(因此无法升级到 .NET4.5 和 EF5)。如果有帮助,我理论上可以升级到 EF 4.3.1。

4

1 回答 1

4

您可以添加一个 ODataQueryOptions 类型的参数并手动应用它,而不是将您的操作标记为 [Queryable]。下面是它的样子:

public class EnrollmentController : ApiController
{
    public object Get(ODataQueryOptions<tblEnrollment> query)
    {
        var context = new ProjectEntities();
        context.ContextOptions.LazyLoadingEnabled = false;
        var queryResults = query.ApplyTo(context.tblEnrollment.AsQueryable());
        return new { enrollment = queryResults };
    }
}
于 2013-01-23T15:38:31.027 回答