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

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>;
我知道如何构建简单的Expression,但是我不知道如何构建这一表达式,“ Any”似乎真的很复杂。
任何电话都很难理解

有人知道如何处理吗?

最佳答案

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。

关键的见解是,此过程很好地映射到功能语言已知的约简。 LINQ to objects通过Aggregate支持它。

10-05 18:36