gpt4 book ai didi

c# - LINQ:使用 AND 序列构建动态过滤器

转载 作者:行者123 更新时间:2023-11-30 17:11:32 25 4
gpt4 key购买 nike

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

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> ;我知道如何构建简单的表达式,但我不知道如何构建这个“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 的未过滤查询开始,并折叠所有查询参数。最终结果是一系列嵌套过滤器,相当于一系列 AND。

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

关于c# - LINQ:使用 AND 序列构建动态过滤器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11365267/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com