我有一个非常好用的asp.net 4.5 Web Api oData v4服务但是我今天遇到了一个问题,在$expand中有嵌套的$filters.
它说here
that OData V4 supports nested filters in $expand. The request below
return People and all their trips with Name “Trip in US”.GET serviceRoot/People?$expand=Trips($filter=Name eq ‘Trip in US’)
它显示了一个很好的数据示例.
Web API for oData v4 Docs here还有一个编码示例
我有这样的HTTP调用:
serviceRoot/Languages?$expand=translations
它会返回一个包含扩展翻译的语言列表,我可以使用以下方法过滤该*列表:
serviceRoot/Languages?$expand=translations&$filter=isoLanguageShortName eq 'en'
但是,我无法使用以下方法过滤扩展的翻译:
serviceRoot/Languages?$expand=translations($filter=languageName eq 'English')
该调用似乎与上面引用的调用相同,效果应与我们的数据相同.
有谁知道我哪里出错了?我是否需要在我的ASP.NET代码中设置一些内容才能使其工作(就像我们需要将MaxExpansionDepth添加到EnableQueryAttribute以便查询更深层次的两个级别)?
解决方法:
这是一个版本问题.版本5.5已添加对该支持的支持.我用v5.5.1测试了sample,它实际上正在工作.
由于@lukkea证实他使用的是5.4.0.
(标题中指出的版本6.1.0对应于odata core库,它们是odata web api库Microsoft.AspNet.OData的依赖项)