标签:Lamda Expression predicate FeedID Func Where id
Func<TObject, bool>是委托(delegate)
Expression<Func<TObject, bool>>是表达式,编译后就会变成delegate,才能运行。
举例:
Expression<Func<int, bool>> ex = x=>x < 100;
Func<int, bool> func = ex.Compile();
然后你就可以调用func:
func(5) //-返回 true
func(200) //- 返回 false
而表达式是不能直接调用的。
=====================================
错误的代码:
//错误的代码
Func<QuestionFeed,
bool
> predicate =
null
;
if
(type == 1)
{
predicate = f => f.FeedID == id && f.IsActive ==
true
;
}
else
{
predicate = f => f.FeedID == id;
}
//_questionFeedRepository.Entities的类型为IQueryable<QuestionFeed>
_questionFeedRepository.Entities.Where(predicate);
上面代码逻辑是根据条件动态生成LINQ查询条件,将Func类型的变量作为参数传给Where方法。
实际上Where要求的参数类型是:Expression<Func<TSource, bool>>。
正确的代码:
//正确的代码
Expression<Func<QuestionFeed,
bool
>> predicate=
null
;
if
(type == 1)
{
predicate = f => f.FeedID == id && f.IsActive ==
true
;
}
else
{
predicate = f => f.FeedID == id;
}
_questionFeedRepository.Entities.Where(predicate);
用委托来执行:把所有的数据从Db中取出后(集合)再给委托来筛选。
用表过式执行时:
把表达式译成SQL语句执行(由EF完成)。
标签:Lamda,Expression,predicate,FeedID,Func,Where,id 来源: https://www.cnblogs.com/wfy680/p/15488234.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。