首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >C# PredicateBuilder Entities:未在指定的LINQ查询表达式中绑定参数'f‘

C# PredicateBuilder Entities:未在指定的LINQ查询表达式中绑定参数'f‘
EN

Stack Overflow用户
提问于 2010-06-01 14:59:31
回答 2查看 13.3K关注 0票数 54

我需要构建一个动态过滤器,并且我想继续使用实体。由于这个原因,我想使用来自albahari的PredicateBuilder。

我创建了以下代码:

代码语言:javascript
复制
var invoerDatums = PredicateBuilder.True<OnderzoeksVragen>();
var inner = PredicateBuilder.False<OnderzoeksVragen>();

foreach (var filter in set.RapportInvoerFilter.ToList())
{
    if(filter.IsDate)
    {
        var date = DateTime.Parse(filter.Waarde);
        invoerDatums = invoerDatums.Or(o => o.Van >= date && o.Tot <= date);
    }
    else
    {
        string temp = filter.Waarde;
        inner = inner.Or(o => o.OnderzoekType == temp);
    }
}

invoerDatums = invoerDatums.And(inner);
var onderzoeksVragen = entities.OnderzoeksVragen
                               .AsExpandable()
                               .Where(invoerDatums)
                               .ToList();

当我运行代码时,只有一个过滤器不是日期过滤器。因此,只填充了内部谓词。当执行谓词时,我得到了以下错误。

未在指定的LINQ查询表达式中绑定参数'f‘。

在搜索答案时,我找到了以下page。但这已经在LINQKit中实现了。

有没有其他人经历过这个错误并知道如何解决它?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-06-02 19:39:37

我遇到了同样的错误,问题似乎是当我使用PredicateBuilder编写的谓词,而这些谓词又由其他使用PredicateBuilder编写的谓词组成时

例如(A或B) AND (X或Y),其中一个构建器创建A或B,一个构建器创建X或Y,第三个构建器对它们进行and运算。

在只有一个级别的谓词的情况下,AsExpandable工作得很好,当引入了多个级别时,我得到了同样的错误。

我找不到任何帮助,但通过一些试验和错误,我能够让事情变得正常。每次我调用谓词时,我都会在它后面加上Expand扩展方法。

以下是一些代码,为简单起见进行了删减:

代码语言:javascript
复制
public static IQueryable<Submission> AddOptionFilter(
    this IQueryable<Submission> query, 
    IEnumerable<IGrouping<int, int>> options)
{
    var predicate = options.Aggregate(
        PredicateBuilder.False<Submission>(),
        (accumulator, optionIds) => accumulator.Or(ConstructOptionMatchPredicate(optionIds).Expand()));
        query = query.Where(predicate.Expand());            
    return query;
}

查询是已经调用了AsExpandable的IQueryable,则ConstructOptionNotMatchPredicate返回一个表达式。

一旦我们克服了这个错误,我们肯定能够在运行时针对实体框架构建复杂的过滤器。

编辑:

由于人们仍然在评论和投票,所以我认为它仍然有用,所以我分享了另一个修复方法。基本上,我已经停止使用LinqKit和它的谓词构建器,转而使用这个Universal Predicate Builder,它具有相同的API,但不需要扩展调用,非常值得一试。

票数 122
EN

Stack Overflow用户

发布于 2012-07-05 06:39:03

我得到了这个错误,Mant101的解释给了我答案,但你可能在寻找一个更简单的导致问题的例子:

代码语言:javascript
复制
// This predicate is the 1st predicate builder
var predicate = PredicateBuilder.True<Widget>();

// and I am adding more predicates to it (all no problem here)
predicate = predicate.And(c => c.ColumnA == 1);
predicate = predicate.And(c => c.ColumnB > 32);
predicate = predicate.And(c => c.ColumnC == 73);

// Now I want to add another "AND" predicate which actually comprises 
// of a whole list of sub-"OR" predicates
if(keywords.Length > 0)
{
    // NOTICE: Here I am starting off a brand new 2nd predicate builder....
    // (I'm not "AND"ing it to the existing one (yet))
    var subpredicate = PredicateBuilder.False<Widget>();

    foreach(string s in keywords)
    {
        string t = s;  // s is part of enumerable so need to make a copy of it
        subpredicate = subpredicate.Or(c => c.Name.Contains(t));
    }

    // This is the "gotcha" bit... ANDing the independent
    // sub-predicate to the 1st one....

    // If done like this, you will FAIL!
//  predicate = predicate.And(subpredicate); // FAIL at runtime!

    // To correct it, you must do this...
    predicate = predicate.And(subpredicate.Expand());  // OK at runtime!
}

希望这能有所帮助!:-)

票数 44
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2947820

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档