PredicateBuilder无法转换为IQueryable?

时间:2012-01-30 16:40:45

标签: linq iqueryable predicate predicatebuilder

我有一个功能:

private IEnumerable<Promotion> MatchesKeyword(IEnumerable<Promotion> list, String keyword)
{
   ...snip...
}

现在执行LINQ查询:

private IEnumerable<Promotion> MatchesKeyword(IEnumerable<Promotion> list, String keyword)
{
   return list.Where(item => item.Name.ContainsText(keyword)
      || item.Description.ContainsText(keyword)
      ...snip...
   );
}

此代码运行良好。

但是i need to convert it要使用PredicateBuilder

private IEnumerable<Promotion> MatchesKeyword(IEnumerable<Promotion> list, String keyword)
{
   var predicate = PredicateBuilder.False<Promotion>();     

   predicate = predicate.Or(item => item.Name.ContainsText(keyword)
         || item.Description.ContainsText(keyword)
         ...snip...
   );

   return list.Where(predicate);
}

奇怪的是,这不会编译。失败的一行是:

return list.Where(predicate);

您可以选择错误:

  • 实例参数:无法从'System.Collections.Generic.IEnumerable'转换为'System.Linq.IQueryable'
  • 'System.Collections.Generic.IEnumerable'不包含'Where'的定义和最佳扩展方法重载'System.Linq.Enumerable.Where(System.Collections.Generic.IEnumerable,System.Func)'具有一些无效的论点
  • 参数2:无法从'System.Linq.Expressions.Expression&gt;'转换到'System.Func'

有什么问题? IEnumerable进入,IEnumerable出来。

我会说实话,我读the page on PredicateBuilder而且我不理解 任何


PredicateBuilder

......并不是说我需要一个理由,问题,实际例子或研究工作来提问。

1 个答案:

答案 0 :(得分:10)

PredicateBuilder需要IQueryable<T>才能发挥其魔力。只需将示例中的最后一行更改为

即可
return list.AsQueryable().Where(predicate);

让它发挥作用。