假设我有以下两个要重构的 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/