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

标签 c# .net linq linq-to-sql refactoring

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

相关文章:

c# - 使用 dataGridView 显示数据库中的数据?

c# - 我应该如何/应该用一个 linq 查询替换嵌套的 foreach ?

c# - 通过 UseUrls 指定监听 HTTP 端口的方式是否正确?

c# - 带有点网核心的自托管进程内 Web API

c# - 将 WPF DataGrid ItemsSource 绑定(bind)到自定义 Table 对象的方法 IEnumerable<TableRow> GetRows()?

c++ - 链接错误 : <LNK1120> <LNK2020> Implement one serialization data class in C++

c# - 为什么 PictureBox.Invalidate() 会导致程序崩溃? System.AccessViolationException异常

c# - LINQ 在列表中选择列表

c# - 选择具有特定属性值的属性

c# - 如何在 LinQ 组中连接字符串