1

我想使用操作过滤器将 Odata uri 转换为 Linq 表达式。我这样做是因为我正在使用生成的表达式来查询非 SQL 业务线系统。在 WCF web api 中,这是微不足道的,因为翻译后的查询被附加为请求对象的属性,如下所示:

var query = (EnumerableQuery)request.Properties["queryToCompose"];

那似乎已经消失了。我可以使用任何公共 api 来完成此操作吗?

4

3 回答 3

1

事实证明,查询已更改请求属性集合中的键。似乎解析查询的内部过滤器在自定义过滤器之后运行,因此不会添加查询值。要获取翻译后的查询,请在控制器操作中调用以下内容。

(EnumerableQuery<T>)this.Request.Properties["MS_QueryKey"];
于 2012-02-26T23:55:35.603 回答
1

我一直在尝试类似的东西。虽然并不完美,但您可以直接从查询字符串中获取 OData 表达式并手动构建 LINQ 表达式:

var queryParams = HttpUtility.ParseQueryString( ControllerContext.Request.RequestUri.Query );
var top = queryParams.Get( "$top" );
var skip = queryParams.Get( "$skip" );
var orderby = queryParams.Get( "$orderby" );

并将其直接应用于您IQueryable或您用于过滤的任何内容。几乎没有那么有用,但它是一个开始。

于 2012-02-24T15:41:50.907 回答
0

查看Linq2Rest。它解决了这个问题。

于 2012-03-11T10:05:03.773 回答