c# – LINQ中的谓词
发布时间:2020-12-15 08:16:24 所属栏目:百科 来源:网络整理
导读:如何在LINQ中的Where谓词中指定条件而不获取空引用异常.例如,如果q是IQueryable,我该怎么做: ExpressionFuncProductEntity,bool predicate = p = !search.CategoryId.HasValue || (search.CategoryId.HasValue search.CategoryId == p.CategoryId);var q2 =
如何在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); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |