我正在努力动态创建这样的查询:
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”似乎真的很复杂。
任何称之为难以理解的
任何人都知道如何处理这个问题?
答案 0 :(得分: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对象通过Aggregate
支持它。