5

这个问题非常相似,但没有给我我需要的东西。

我正在使用 Entity Framework 6。我的数据库有两个表,Customers 和 CustomerTypes。我为每个创建了一个 ViewModel。客户可以有一个类型:

public class Customer
{
    public int CustomerID { get; set; }
    public string CustomerName { get; set; }
    public CustomerTypeViewModel CustomerType { get; set; }
}

public class CustomerTypeViewModel
{
    public int CustomerTypeID { get; set; }
    public string CustomerTypeDescription { get; set; }
}

我有一个客户控制器,它公开了一个返回类型为 IQueryable 的 odata 操作方法:

[HttpPost, Queryable(AllowedQueryOptions = AllowedQueryOptions.All)]
    public IQueryable<CustomerViewModel> GetCustomersMatchingCriteria([FromBody]ODataActionParameters parameters)
    {
        var criteria = (CustomerMassUpdateCriteriaViewModel)parameters["Criteria"];

        return Common.Customers.GetCustomerMassUpdateCriteriaResults(criteria,
            ConfigurationManager.AppSettings["CLIENT_ID"]).Select(
            c => new CustomerViewModel()
            {
                CustomerID = c.CustomerID,
                CustomerName = c.CustomerName,
                CustomerType = new CustomerTypeViewModel() 
                {
                    CustomerTypeDescription = c.CustomerType.CustomerTypeDescription
                }
            });
    }

Common.Customers.GetCustomerMassUpdateCriteriaResults 方法只返回 Customer 的 IQueryable,它是实际的实体。

问题是,当使用以下查询字符串选项调用此控制器方法时:

$expand=CustomerType
$select=CustomerID,CustomerName,CustomerType/CustomerTypeDescription

抛出此异常:

“ObjectContent`1”类型无法序列化内容类型“application/json”的响应正文;charset=utf-8'.","type":"System.InvalidOperationException"

DbIsNullExpression 的参数必须引用原始类型、枚举类型或引用类型。

从 $select 列表中删除 $expand 选项和关联的 CustomerType/CustomerTypeDescription 属性不会产生错误。

我觉得我在这里遗漏了一些明显的东西。有任何想法吗?

第一次编辑:

通过 ToList() 扩展方法枚举结果并返回 IEnumerable 而不是 IQueryable 成功扩展了 CustomerType 导航属性,但我的 ODATA $select 列表不再在数据库级别受到尊重。这不是违背了使用 ODATA 的目的吗?

4

1 回答 1

0

例外 :

“ObjectContent`1”类型无法序列化内容类型“application/json”的响应正文;charset=utf-8'.","type":"System.InvalidOperationException"

据我所知,这是由于请求如何达到 OData 格式。请求应到达 OData 路由以进行格式化。如果您可以在 global.asax 中的RouteConfig.RegisterRoutesWebApiConfig.Register之前移动GlobalConfiguration.Configuration.EnableOData()可能会有所帮助。

于 2013-11-08T05:37:16.540 回答