我有一个非常好用的asp.net 4.5 Web Api oData v4服务但是今天我遇到了一个问题,在$ expand中嵌套了$ filters。
它说here
OData V4支持$ expand中的嵌套过滤器。请求如下 返回人们及所有旅行的名字"在美国旅行"。
GET serviceRoot / People?$ expand = Trips($ filter =姓名eq'美国之旅')
它显示了一个很好的数据示例。
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以便查询更深层次的两个级别)?
答案 0 :(得分:2)
这是版本问题。版本5.5已添加对该支持的支持。我使用sample测试了v5.5.1,它实际上正在运行。
@lukkea证实他使用的是5.4.0。
(标题中指出的版本6.1.0对应于odata core库,这是odata web api库Microsoft.AspNet.OData的依赖关系)