c# – LINQ中的谓词

如何在LINQ中的Where谓词中指定条件而不获取空引用异常.例如,如果q是IQueryable,我该怎么做:
Expression<Func<ProductEntity,bool>> predicate = p => !search.CategoryId.HasValue || (search.CategoryId.HasValue && search.CategoryId == p.CategoryId);

var q2 = q.Where(predicate);

这里搜索一个对象,它包含可能或不可能设置的搜索条件,如search.CategoryId可能没有设置,但如果是,我想获得由该条件设置的产品.

当我这样做时,我得到空引用异常.

解决方法

你可以使用 null-coalescing operator ??用认值替换可能的空值.以下几组尝试匹配search.Category(如果存在)或仅创建“always true”表达式.这将由任何优秀的Linq查询提供程序(例如LinqTosql)进行优化.
Expression<Func<ProductEntity,bool>> predicate = (p => (search.CategoryId ?? p.CategoryId) == p.CategoryId));

var q2 = q.Where(predicate);

另一种可能性是使用PredicateBuilder动态编写查询谓词.这就是我使用类似模式进行搜索的方式:

var predicate = PredicateBuilder.True<Order>();

if (search.OrderId))
{
   predicate = predicate.And(a => sqlMethods.Like(a.OrderID,search.OderID);  
}
// ...
var results = q.Where(predicate);

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...