3

我正在努力动态创建这样的查询:

Dictionary<string, Guid> parms = new Dictionary<string, Guid>();

foreach (var kvp in parms)
{
    var exp = ReportDefinitions.Where(x=> 
        x.Discriminants.Any(y=> y.Key == kvp.Key && y.Value == kvp.Value)
// && more conditions to add here at each cycle
        );  
}

其中 ReportDefinitions.Discriminants 是IDictionary<string, Guid>; 我知道如何构建简单的表达式,但我不知道如何构建这个“任何”似乎真的很复杂。任何电话都很难理解

任何人都知道如何处理这个?

4

1 回答 1

2
var query = parms.Aggregate(ReportDefinitions.AsQueryable(),
  (a, kvp) => a.Where(x => x.Discriminants.Any(
     y => y.Key == kvp.Key && y.Value == kvp.Value)));

我们从一个未过滤的 ReportDefinitions 查询开始,并折叠所有查询参数。最终结果是一系列嵌套过滤器,相当于一系列 AND。

关键的见解是这个过程很好地映射到从函数式语言中知道的reduce 。LINQ to objects 通过Aggregate.

于 2012-07-06T17:00:30.323 回答