当前位置:  开发笔记 > 编程语言 > 正文

LINQ,查询大过滤器

如何解决《LINQ,查询大过滤器》经验,为你挑选了1个好方法。

我正在构建一个应用程序的一部分,该部分围绕从数据库中提取有关事务的信息.由于数据的性质,表中有许多我想要过滤的列.我有一个包含15个字段的过滤器选择框,我希望能够为LINQ语句构建一个where子句.当我想要某些字段为空时,有趣的部分就出现了.例如,我希望能够过滤以下任何一个或全部:

交易类型

响应代码

交易金额

还有很多

我可以建立一个看起来像的谓词

Func pred = t => t.ResponseCode == ResponseCode && t.TransactionType == TransactionType && t.TransactionAmount > 100.00;

但是为了能够选择在谓词中包含哪些字段,我将谓词连接在一起:

Func pred = t => true;
if(ResponseCode != null)
   pred.AndAlso(t => t.ResponseCode == ResponseCode);
// Rinse and repeat

然后将该谓词传递给LINQ语句的where子句.

这完全按我想要的方式工作,但相当复杂.有没有其他方法可以做到这一点?

更新:感谢Justice的评论.我没有使用LINQ to SQL,我在存储库中的对象集合上使用LINQ.您将如何以编程方式构建表达式过滤器?



1> Amy B..:

在动态SQL中...由于您只有一个WHERE子句 - 您必须使用AND连接谓词.

在linq查询构造中...您可以获得任意数量的WHERE子句.当它翻译查询时,Linq会将它们和你们联系在一起.

例:

IQueryable query = db.Transactions;

if (filterByTransactionType)
{
  query = query.Where(t => t.TransactionType == theTransactionType);
}
if (filterByResponseCode)
{
  query = query.Where(t => t.ResponseCode == theResponseCode);
}
if (filterByAmount)
{
  query = query.Where(t => t.TransactionAmount > theAmount);
}

另一个例子:

List>> filters = GetFilterExpressions();

IQueryable query = db.Transactions;
filters.ForEach(f => query = query.Where(f));

推荐阅读
小白也坚强_177
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有