gpt4 book ai didi

c# - 如何重构多个相似的 Linq 查询?

转载 作者:行者123 更新时间:2023-12-03 23:07:58 28 4
gpt4 key购买 nike

假设我有以下两个要重构的 Linq 查询:

var someValue1 = 0;
var someValue2= 0;
var query1 = db.TableAs.Where( a => a.TableBs.Count() > someValue1 )
.Take( 10 );
var query2 = db.TableAs.Where( a => a.TableBs.First().item1 == someValue2)
.Take( 10 );

请注意,只有Where 参数发生变化。有什么方法可以将查询放入方法中并将Where 参数作为参数传递吗?

最佳答案

当然有。 where 参数只是 Func<T, bool> 类型的简单闭包(其中 T 是数据库项的类型 - 我不知道您的代码中的它们),您可以将其包装到(匿名)函数中。

Func<Func<T, bool>, IEnumerable<T>> MakeQuery = (Func<T, bool> whereParam) => db.TableAs.Where(whereParam).Take(10);

像这样使用

var query1 = MakeQuery(a => a.TableBS.Count() > someValue1);

关于c# - 如何重构多个相似的 Linq 查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/863169/

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