Csharp/C#教程:LINQ:使用AND序列构建动态filter分享


LINQ:使用AND序列构建动态filter

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

Dictionary parms = new Dictionary(); 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 ; 我知道如何构建简单的Expression但我无法弄清楚如何构建这个“Any”似乎真的很复杂。 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的未过滤查询开始,并在所有查询参数中折叠。 最终结果是一系列嵌套filter,它们等同于一系列AND。

关键的见解是,这个过程可以很好地映射到函数式语言中已知的简化 。 LINQ to对象通过Aggregate支持它。

上述就是C#学习教程:LINQ:使用AND序列构建动态filter分享的全部内容,如果对大家有所用处且需要了解更多关于C#学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/cdevelopment/948958.html

(0)
上一篇 2021年11月17日
下一篇 2021年11月17日

精彩推荐