OData中的区分大小写属性时出现AmbiguousMatchException

DIl*_*d K 5 c# odata

我有两个名称相同,大小写不同的属性,Title并且TITLE

public class Product
{
    [Key]
    public Guid Id { get; set; }
    public string Name { get; set; }
    public decimal Price { get; set; }
    public string Category { get; set; }

    [NotMapped]
    public virtual string Title { get; set; }

    public string TITLE { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

我在OData配置中包含Title:

ODataModelBuilder builder = new ODataConventionModelBuilder();
        builder.EntitySet<Product>("Products");
        builder.EntityType<Product>().Property(a => a.Title);
        config.MapODataServiceRoute(
        routeName: "ODataRoute",
        routePrefix: null,
        model: builder.GetEdmModel());
Run Code Online (Sandbox Code Playgroud)

这是OData控制器的操作:

  public IHttpActionResult Get(ODataQueryOptions<Product> queryOptions, CancellationToken cancellationToken)
  {
     Context = GetContext();
     var products = Context.GetEntities<Product>();
     var result = queryOptions.ApplyTo(products);
     return Ok(result);
  }
Run Code Online (Sandbox Code Playgroud)

当我发送https://localhost:44326/Products?$select=Id,TITLE请求时,queryOptions.ApplyTo(products);我会收到以下异常:

System.Reflection.AmbiguousMatchException:'找到了模糊的匹配项。

我想使用$ select获得Title和TITLE属性。有谁知道如何解决这个问题?

Dil*_*d K 0

这是 OData 的问题。该问题将在7.3版本中修复。这是拉取请求: https: //github.com/OData/WebApi/pull/1907